问题遇到的现象和发生背景
不同方式复制表,有什么区别?
【pgsql】select * into tab_b from tab_a 和Navicat里面的复制表有什么不同,内部具体执行是怎么样的?
这里只提到了两种简单的方式,或者说有同学能够提供更多的复制表的方法进行讨论?期待……
不同方式复制表,有什么区别?
【pgsql】select * into tab_b from tab_a 和Navicat里面的复制表有什么不同,内部具体执行是怎么样的?
这里只提到了两种简单的方式,或者说有同学能够提供更多的复制表的方法进行讨论?期待……
pg是postgresql这个数据库的简称,
Navicat是一个系列软件的系列名称,包含了十几款软件,其中有8款软件是数据库图形化管理工具,包括了 for mysql /for oracle/for postgresql/for sqlserver 等等,下面这个链接是Navicat的软件清单
只要你连接的是同一个数据库的同一个版本,不管你用什么软件去连接管理它,语法都是一样的。
你现在用的pg数据库,一样的可以用navicat去连接它,只是要用navicat for postgresql 或者navicat Premium而已
使用navicat一样可以连接pg数据库,使用菜单里的复制表功能,当然也可以用sql命令来执行
这个复制表功能不过就是个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。