oracle 复制一个表数据 到另一个表中,select into与insert into

本文介绍两种复制表数据的方法:INSERT INTO SELECT用于已有目标表的情况,而SELECT INTO FROM则适用于目标表尚未创建的场景。通过具体实例展示如何进行操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近工作需要把另一个表复制到新的数据库中,前提两个数据库之间建立了dblink,所以使用的方法是: create table table1 as (table2),
table1 代表的是要插入数据库表名称,table2 数据库来源。
注意的是:这里目标数据库的表不需要建立,可以直接使用。

create table gw_dict_bd_dd_info as  (select * from bd_dd_info@phsdb);
 1.INSERT INTO SELECT语句 
      语句形式为:Insert into Table2(field1,field2,...) select value1,value2,... from Table1

      要求目标表Table2必须存在,由于目标表Table2已经存在,所以我们除了插入源表Table1的字段外,还可以插入常量。示例如下:

INSERT INTO SELECT语句复制表数据
   --1.创建测试表
    create TABLE Table1
    (
        a varchar(10),
        b varchar(10),
        c varchar(10),
        CONSTRAINT [PK_Table1] PRIMARY KEY CLUSTERED
        (
            a ASC
        )
    ) ON [PRIMARY]

    create TABLE Table2
    (
        a varchar(10),
        c varchar(10),
        d int,
        CONSTRAINT [PK_Table2] PRIMARY KEY CLUSTERED
        (
            a ASC
        )
    ) ON [PRIMARY]
    GO
    --2.创建测试数据
    Insert into Table1 values('赵','asds','90')
    Insert into Table1 values('钱','asds','100')
    Insert into Table1 values('孙','asds','80')
    Insert into Table1 values('李','asds',null)
    GO
    select * from Table2

    --3.INSERT INTO SELECT语句复制表数据
    Insert into Table2(a, c, d) select a,c,5 from Table1
    GO

    --4.显示更新后的结果
    select * from Table2
    GO
    --5.删除测试表
    drop TABLE Table1
    drop TABLE Table2

      2.SELECT INTO FROM语句

      语句形式为:SELECT vale1, value2 into Table2 from Table1

      要求目标表Table2不存在,因为在插入时会自动创建表Table2,并将Table1中指定字段数据复制到Table2中。示例如下:

SELECT INTO FROM创建表并复制表数据
   --1.创建测试表
    create TABLE Table1
    (
        a varchar(10),
        b varchar(10),
        c varchar(10),
        CONSTRAINT [PK_Table1] PRIMARY KEY CLUSTERED
        (
            a ASC
        )
    ) ON [PRIMARY]
    GO

    --2.创建测试数据
    Insert into Table1 values('赵','asds','90')
    Insert into Table1 values('钱','asds','100')
    Insert into Table1 values('孙','asds','80')
    Insert into Table1 values('李','asds',null)
    GO

    --3.SELECT INTO FROM语句创建表Table2并复制数据
    select a,c INTO Table2 from Table1
    GO

    --4.显示更新后的结果
    select * from Table2
    GO
    --5.删除测试表
    drop TABLE Table1
    drop TABLE Table2
Oracle数据库中,将一个的字段复制一张中可以通过多种方法实现。以下是几种常见的方法: ### 方法一:使用`INSERT INTO ... SELECT`语句 这种方法适用于将一张中的数据插入到一张中,前提是两张具有相同的字段结构。 ```sql INSERT INTO table2 (column1, column2, column3) SELECT column1, column2, column3 FROM table1 WHERE condition; ``` ### 方法二:使用`CREATE TABLE AS SELECT`语句 这种方法适用于创建一个,并将一张数据复制到新中。 ```sql CREATE TABLE table2 AS SELECT column1, column2, column3 FROM table1 WHERE condition; ``` ### 方法三:使用`ALTER TABLE`语句添加新字段并更新数据 如果两张已经存在,并且你只想复制某些字段的数据,可以使用`ALTER TABLE`语句添加新字段,然后使用`UPDATE`语句更新数据。 ```sql ALTER TABLE table2 ADD (column1 datatype, column2 datatype, column3 datatype); UPDATE table2 t2 SET (t2.column1, t2.column2, t2.column3) = (SELECT t1.column1, t1.column2, t1.column3 FROM table1 t1 WHERE t1.id = t2.id); ``` ### 方法四:使用`MERGE`语句 `MERGE`语句可以用于将数据从一张合并到一张中。 ```sql MERGE INTO table2 t2 USING table1 t1 ON (t1.id = t2.id) WHEN MATCHED THEN UPDATE SET t2.column1 = t1.column1, t2.column2 = t1.column2, t2.column3 = t1.column3 WHEN NOT MATCHED THEN INSERT (t2.id, t2.column1, t2.column2, t2.column3) VALUES (t1.id, t1.column1, t1.column2, t1.column3); ``` 这些方法可以根据具体需求选择使用,确保在操作前备份数据以防止数据丢失。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

老王学Java

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值