Oracle 复制表结构(含索引、主键)操作指南

Oracle 复制表结构(含索引、主键)操作指南

1. 复制基础表结构

sql 复制代码
-- 创建空表结构(不复制数据)
CREATE TABLE new_table AS 
SELECT * FROM old_table 
WHERE 1=0;

2. 复制主键约束

sql 复制代码
-- 查询原表主键信息
SELECT constraint_name, column_name
FROM user_cons_columns
WHERE table_name = 'OLD_TABLE'
AND constraint_name IN (
    SELECT constraint_name
    FROM user_constraints
    WHERE table_name = 'OLD_TABLE'
    AND constraint_type = 'P'
);

-- 创建新主键(需替换实际约束名和列名)
ALTER TABLE new_table 
ADD CONSTRAINT new_pk_constraint PRIMARY KEY (column1, column2);

3. 复制索引

sql 复制代码
-- 查询原表索引信息
SELECT index_name, column_name, index_type, uniqueness
FROM user_ind_columns
JOIN user_indexes USING (index_name)
WHERE table_name = 'OLD_TABLE';

-- 创建新索引(示例)
CREATE INDEX new_idx_name ON new_table (column_name);
CREATE UNIQUE INDEX new_uniq_idx ON new_table (column1, column2);

4. 复制其他约束(可选)

sql 复制代码
-- 检查约束示例
ALTER TABLE new_table 
ADD CONSTRAINT chk_salary CHECK (salary > 0);

-- 唯一约束示例
ALTER TABLE new_table 
ADD CONSTRAINT uniq_email UNIQUE (email);

注意事项

  1. 对象命名冲突:建议为新约束/索引添加前缀(如 new_pk_

  2. 权限需求:需要 CREATE TABLE CREATE INDEX 权限

  3. 未包含对象:

    • 不会自动复制外键约束

    • 不包含触发器、序列等对象

    • 不复制表注释和列注释

  4. 数据存储参数:默认使用当前用户的表空间设置

相关推荐
2401_883600252 分钟前
怎么为MongoDB事务调优:将读操作尽量移到事务外面执行.txt
jvm·数据库·python
m0_493934536 分钟前
Go 中嵌入类型字段在派生结构体字面量中的初始化规则详解
jvm·数据库·python
Polar__Star10 分钟前
PHP新手如何评估AI成本_预算控制方法【教程】
jvm·数据库·python
ん贤11 分钟前
数据库事务
数据库·mysql·事务
隐于花海,等待花开14 分钟前
数据库面试题常问详细总结
数据库
爱学习的小邓同学16 分钟前
MySQL --- MySQL库和表的操作
数据库·mysql
m0_4939345317 分钟前
TensorFlow如何监控内存使用情况_结合tf.summary记录关键指标信息
jvm·数据库·python
以神为界18 分钟前
数据库入门全指南:从基础概念到实操操作(含SQL+Navicat)
网络·数据库·sql·安全
Elastic 中国社区官方博客25 分钟前
Elasticsearch:快速近似 ES|QL - 第二部分
大数据·数据库·sql·elasticsearch·搜索引擎·全文检索
Polar__Star26 分钟前
Go语言中--=运算符详解:位右移赋值操作的原理与实践
jvm·数据库·python