秦时明月之君临天下 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 maixpy训练模型,模型训练好了以后,开发板通电会报错,不知道是什么问题
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 有没有帮写代码做实验仿真的
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥30 vmware exsi重置后登不上
  • ¥15 c++头文件不能识别CDialog
  • ¥15 Excel发现不可读取的内容