秦时明月之君临天下 2022-03-22 20:25 采纳率: 0%
浏览 19

【pgsql】select * into tab_b from tab_a 和Navicat里面的复制表有什么不同,内部具体执行是怎么样的?

问题遇到的现象和发生背景

不同方式复制表,有什么区别?

【pgsql】select * into tab_b from tab_a 和Navicat里面的复制表有什么不同,内部具体执行是怎么样的?

这里只提到了两种简单的方式,或者说有同学能够提供更多的复制表的方法进行讨论?期待……

  • 写回答

1条回答 默认 最新

  • DarkAthena ORACLE应用及数据库设计方案咨询师 2022-03-22 21:10
    关注

    pg是postgresql这个数据库的简称,
    Navicat是一个系列软件的系列名称,包含了十几款软件,其中有8款软件是数据库图形化管理工具,包括了 for mysql /for oracle/for postgresql/for sqlserver 等等,下面这个链接是Navicat的软件清单

    只要你连接的是同一个数据库的同一个版本,不管你用什么软件去连接管理它,语法都是一样的。
    你现在用的pg数据库,一样的可以用navicat去连接它,只是要用navicat for postgresql 或者navicat Premium而已


    使用navicat一样可以连接pg数据库,使用菜单里的复制表功能,当然也可以用sql命令来执行

    img

    这个复制表功能不过就是个create table new_table as select * from old_table 命令罢了,如果是仅复制结构,只需要加一个条件 where 1=2
    一般情况下,都是使用create table as 来复制表,你题目中的 select * into 极少使用,甚至在pg的官方文档里也是推荐使用create table as
    http://postgres.cn/docs/13/sql-selectinto.html

    CREATE TABLE AS在功能上与 SELECT INTO相似。CREATE TABLE AS 是被推荐的语法,因为这种形式的SELECT INTO在ECPG 或PL/pgSQL中不可用,因为它们对 INTO子句的解释不同。此外, CREATE TABLE AS提供的功能是 SELECT INTO的超集。
    与CREATE TABLE AS相比,SELECT INTO 不允许指定属性,就像带有USING method的表访问方法或者带有TABLESPACE tablespace_name的表的表空间。 如果必要,使用CREATE TABLE AS。

    评论 编辑记录

报告相同问题?

问题事件

  • 创建了问题 3月22日

悬赏问题

  • ¥15 在若依框架下实现人脸识别
  • ¥15 网络科学导论,网络控制
  • ¥100 安卓tv程序连接SQLSERVER2008问题
  • ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同