秦时明月之君临天下 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 kafka topic 所有分副本数修改
  • ¥15 小程序中fit格式等运动数据文件怎样实现可视化?(包含心率信息))
  • ¥15 如何利用mmdetection3d中的get_flops.py文件计算fcos3d方法的flops?
  • ¥40 串口调试助手打开串口后,keil5的代码就停止了
  • ¥15 电脑最近经常蓝屏,求大家看看哪的问题
  • ¥60 高价有偿求java辅导。工程量较大,价格你定,联系确定辅导后将采纳你的答案。希望能给出完整详细代码,并能解释回答我关于代码的疑问疑问,代码要求如下,联系我会发文档
  • ¥50 C++五子棋AI程序编写
  • ¥30 求安卓设备利用一个typeC接口,同时实现向pc一边投屏一边上传数据的解决方案。
  • ¥15 SQL Server analysis services 服务安装失败
  • ¥15 基于面向对象的图书馆借阅管理系统