KingbaseES 数据表复制语句的功能差异
Kingbase 数据表复制操作
数据库使用过成中,经常会遇到在现有的表结构基础上,对表结构进行复制。在KingbaseES数据库可以采用select into,create table as select,create table like的方式进行数据表的复制操作。
但表复制操作又有些差异。本文将主要介绍Kingbase数据库的表复制的使用和差异。
-- 源表:
demo=# \d+ table1
数据表 "public.table1"
栏位 | 类型 | 校对规则 | 可空的 | 预设 | 存储 | 统计目标 | 描述
------+---------+----------+----------+------------------------------------+----------+----------+--------
c1 | integer | | not null | nextval('table1_c1_seq'::regclass) | plain | | 主键
c2 | numeric | | | | main | | 数值
c3 | integer | | | 0 | plain | | 默认值
c4 | varchar | | | | extended | | 字符
c5 | integer | | | | plain | | 索引
c6 | varchar | | | | extended | | 唯一值
c7 | integer | | | | plain | | 外键
索引:
"con_public_table1_constraint_1" PRIMARY KEY, btree (c1)
"con_public_table1_constraint_2" UNIQUE CONSTRAINT, btree (c6)
"inxex_public_table1_index_1" UNIQUE, btree (c5)
外部键(FK)限制:
"fkey_public_table1_fkey_1" FOREIGN KEY (c7) REFERENCES foreigntable(c1)
访问方法 heap
demo=# select count(1) from table1;
count
-------
2
(1 行记录
源表结构:
- c1 自增主键
- c2 numeric类型字段
- c3 int 类型设置默认值
- c4 numeric类型字段
- c5 字段上创建索引
- c6 UNIQUE唯一值
- c7 外键
1.select into
采用 (select into)方式复制表结构
CREATE TABLE AS创建一个新表并且用一个查询计算得到的数据填充它。新表的列具有和SELECT的输出列相关的名称和数据类型。
demo=# select * into tableinto from table1 ;
SELECT 2
-- 表结构
demo=# \d+ tableinto
数据表 "public.tableinto"
栏位 | 类型 | 校对规则 | 可空的 | 预设 | 存储 | 统计目标 | 描述
------+---------+----------+--------+------+----------+----------+------
c1 | integer | | | | plain | |
c2 | numeric | | | | main | |
c3 | integer | | | | plain | |
c4 | varchar | | | | extended | |
c5 | integer | | | | plain | |
c6 | varchar | | | | extended | |
c7 | integer | | | | plain | |
访问方法 heap
demo=# select * from tableinto ;
c1 | c2 | c3 | c4 | c5 | c6 | c7
----+-----+----+----+----+----+----
5 | 2.5 | 4 | a | 5 | a | 1
6 | 2.5 | 4 | b | 6 | b | 1
(2 行记录)
结论:(select into)复制表,仅仅复制表基本结构和表数据。不会复制表索引,唯一行限制,主键,外键等对象。
2.create table as select
采用 (create table as select)方式复制表结构
CREATE TABLE AS创建一个表,并且用由一个SELECT命令计算出来的数据填充该表。该表的列具有和SELECT的输出列相关的名称和数据类型(不过可以通过给出一个显式的新列名列表来覆盖这些列名)。新表不会跟踪源表的后续变化。
demo=# create table tableas as select * from table1 ;
SELECT 2
-- 表结构
demo=# \d+ tableas
数据表 "public.tableas"
栏位 | 类型 | 校对规则 | 可空的 | 预设 | 存储 | 统计目标 | 描述
------+---------+----------+--------+------+----------+----------+------
c1 | integer | | | | plain | |
c2 | numeric | | | | main | |
c3 | integer | | | | plain | |
c4 | varchar | | | | extended | |
c5 | integer | | | | plain | |
c6 | varchar | | | | extended | |
c7 | integer | | | | plain | |
访问方法 heap
demo=# select count(1) from tableas ;
count
-------
2
(1 行记录)
结论:(create table as select)复制表,仅仅复制表基本结构和表数据。不会复制表索引,唯一限制,主键,外键等对象。
3.create table like
采用 (create table like)方式复制表结构
CREATE TABLE LIKE创建表的形式允许您精确地复制现有表定义(不复制其数据),其创建的表除了表名和源表不一样外,其余所有的细节都是一样的。但是没有源表的数据。
语法
CREATE TABLE table_name ({ LIKE source_table [ like_option ... ] }
)
like_option 是:
{ INCLUDING | EXCLUDING } { COMMENTS | CONSTRAINTS | DEFAULTS | GENERATED |
IDENTITY | INDEXES | STATISTICS | STORAGE | ALL }
demo=# create table tablelike (like table1 including all) ;
CREATE TABLE
-- 表结构
demo=# \d+ tablelike
数据表 "public.tablelike"
栏位 | 类型 | 校对规则 | 可空的 | 预设 | 存储 | 统计目标 | 描述
------+---------+----------+----------+------------------------------------+----------+----------+--------
c1 | integer | | not null | nextval('table1_c1_seq'::regclass) | plain | | 主键
c2 | numeric | | | | main | | 数值
c3 | integer | | | 0 | plain | | 默认值
c4 | varchar | | | | extended | | 字符
c5 | integer | | | | plain | | 索引
c6 | varchar | | | | extended | | 唯一值
c7 | integer | | | | plain | | 外键
索引:
"tablelike_pkey" PRIMARY KEY, btree (c1)
"tablelike_c5_idx" UNIQUE, btree (c5)
"tablelike_c6_key" UNIQUE CONSTRAINT, btree (c6)
访问方法 heap
demo=# select count(1) from tablelike ;
count
-------
0
(1 行记录)
结论:(create table like)复制表,创建出来的新表包含源表的完整表结构、注释和索引信息等。不会复制表数据内容。
注意:KingbaseES数据like建表与Mysql对serial字段处理方式有些差别:Mysql新表的serial字段为单独创建,与源表无关;Kes新表的serial字段与源表共用一个sequence,不会重新初始化新的sequence。
like 选项可以配置属性:
{ INCLUDING | EXCLUDING } { COMMENTS | CONSTRAINTS | DEFAULTS | GENERATED |
IDENTITY | INDEXES | STATISTICS | STORAGE | ALL }
INCLUDING:指定INCLUDING 复制属性,
EXCLUDING:指定EXCLUDING省略属性。
INCLUDING COMMENTS
复制列、约束和索引的注释将被复制。
INCLUDING CONSTRAINTS
CHECK 约束将被复制。
INCLUDING DEFAULTS
复制列定义的默认表达式将被复制。
INCLUDING GENERATED
复制列定义的任何生成表达式都将被复制。
INCLUDING IDENTITY
复制列定义的任何标识规范都将被复制。
INCLUDING INDEXES
原始表上的Indexes、PRIMARY KEY、UNIQUE、和EXCLUDE约束将在新表上创建。
INCLUDING STATISTICS
扩展的统计信息被复制到新表中。
INCLUDING STORAGE
STORAGE将复制复制列定义的设置。
INCLUDING ALL
INCLUDING ALL是选择所有可用的单独选项的缩写形式。
KingbaseES 数据表复制语句的功能差异的更多相关文章
- oracle SELECT INTO 和 INSERT INTO SELECT 两种表复制语句详解
我们经常会遇到需要表复制的情况,如将一个table1的数据的部分字段复制到table2中,或者将整个table1复制到table2中,这时候我们就要使用SELECT INTO 和 INSERT INT ...
- SELECT INTO 和 INSERT INTO SELECT 两种表复制语句详解(SQL数据库和Oracle数据库的区别)
https://www.cnblogs.com/mq0036/p/4155136.html 我们经常会遇到需要表复制的情况,如将一个table1的数据的部分字段复制到table2中,或者将整个tabl ...
- 问题:oracle select into;结果:oracle SELECT INTO 和 INSERT INTO SELECT 两种表复制语句详解
oracle SELECT INTO 和 INSERT INTO SELECT 两种表复制语句详解 (2011-07-08 08:59:47) 转载▼ 标签: it 分类: oracle 我们经常会遇 ...
- SELECT INTO 和 INSERT INTO SELECT 两种表复制语句
Insert是T-sql中常用语句,Insert INTO table(field1,field2,...) values(value1,value2,...)这种形式的在应用程序开发中必不可少.但我 ...
- Oracle数据库表复制语句
Insert是T-sql中常用语句,Insert INTO table(field1,field2,...) values(value1,value2,...)这种形式的在应用程序开发中必不可少.但我 ...
- SELECT INTO 和 INSERT INTO SELECT 两种表复制语句.txt
Insert是T-sql中常用语句,Insert INTO table(field1,field2,...) values(value1,value2,...)这种形式的在应用程序开发中必不可少.但我 ...
- SQL中两种表复制语句
Insert是T-sql中常用语句,Insert INTO table(field1,field2,...) values(value1,value2,...)这种形式的在应用程序开发中必不可少.但我 ...
- oracle数据库【表复制】insert into select from跟create table as select * from 两种表复制语句区别
create table as select * from和insert into select from两种表复制语句区别 create table targer_table as select ...
- PostgreSQL SELECT INTO和INSERT INTO SELECT 两种表复制语句
SELECT INTO和INSERT INTO SELECT两种表复制语句都可以用来复制表与表之间的数据,但是它们之间也有区别. 建表语句: bas_custom_rel表 CREATE TABLE ...
- select into from和insert into select from两种表复制语句区别
select into from和insert into select from两种表复制语句都是将源表source_table的记录插入到目标表target_table,但两句又有区别. 第一句(s ...
随机推荐
- Java容器及其常用方法汇总
1 概述 Java Collections 框架中包含了大量的接口及其实现类和操作它们的算法,主要包括列表(List).集合(Set).映射(Map),如下: 接口 实现类 数据结构 初始容量 加载因 ...
- oracle sqlplus命令详解(官方示例)
以为内容选自Oracle官方文档,只讲command-line: 规范:<变量名> , {举例} , a | b 枚举可选值,(XX)描述 ------------------------ ...
- ORA-16019 和 ORA-16018 错误的处理方法
一. ORA-16019 和 ORA-16018 错误产生描述 同事在修改归档目录,一不小心把参数设置错误了, 他设置的是log_archive_dest参数. 这个参数和默认log_archive_ ...
- React18 之 Suspense
我们是袋鼠云数栈 UED 团队,致力于打造优秀的一站式数据中台产品.我们始终保持工匠精神,探索前端道路,为社区积累并传播经验价值. 本文作者:佳岚 Suspense Suspense 组件我们并不陌生 ...
- 【Android逆向】frida hook so 函数
1. apk来自52pojie 链接:https://pan.baidu.com/s/1vKC1SevvHfeI7f0d2c6IqQ 密码:u1an 2.apktool反编译apk,拿到so文件 ja ...
- Docker进阶之02-Swarm集群入门实践
Docker集群概述 Docker集群有2种方案: 1.在Docker Engine 1.12之前的集群模式被称为经典集群,这是通过API代理系统实现的集群,目前已经不再维护. 2.自Docker E ...
- 【LeetCode链表#8】翻转链表(双指针+递归)/K个一组翻转
翻转链表 力扣题目链接(opens new window) 题意:反转一个单链表. 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4-> ...
- 【LeetCode链表#7】设计一个链表并实现常见的操作方法
设计链表 题目 力扣题目链接 设计链表的实现.您可以选择使用单链表或双链表.单链表中的节点应该具有两个属性:val 和 next.val 是当前节点的值,next 是指向下一个节点的指针/引用.如果要 ...
- 文心一言 VS 讯飞星火 VS chatgpt (204)-- 算法导论15.3 3题
三.考虑矩阵链乘法问题的一个变形:目标改为最大化矩阵序列括号化方案的标量乘法运算次数,而非最小化.此问题具有最优子结构性质吗?需要写代码的时候,请用go语言. 文心一言,代码正常运行: 首先,我们要明 ...
- 【Azure Cloud Service(Extended Support)】如何使用外延服务迁移应用?
问题一:迁移到云服务扩展后,之前经典版的云服务的部署槽会变成单一的部署槽,关于两个云服务扩展版之间的部署交换能否提供一个演示? 对于具有双槽的云服务(Classic),根据文档中的建议,在迁移到云服务 ...