`
tangleilei
  • 浏览: 14050 次
  • 来自: 上海
社区版块
存档分类
最新评论

insert into and insert into from

 
阅读更多
SELECT INTO 和 INSERT INTO SELECT 两种表复制语句


      Insert是T-sql中常用语句,Insert INTO table(field1,field2,...) values(value1,value2,...)这种形式的在应用程序开发中必不可少。但我们在开发、测试过程中,经常会遇到需要表复制的情况,如将一个table1的数据的部分字段复制到table2中,或者将整个table1复制到table2中,这时候我们就要使用SELECT INTO 和 INSERT INTO SELECT 表复制语句了。

      1.INSERT INTO SELECT语句

      语句形式为:Insert into Table2(field1,field2,...) select value1,value2,... from Table1

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


   --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中。示例如下:


   --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


出处http://www.cnblogs.com/freshman0216/archive/2008/08/15/1268316.html
分享到:
评论

相关推荐

    ORACLE INSERT INTO SELECT *FROM 分批提交例子

    ORACLE INSERT INTO SELECT *FROM 分批提交例子

    Insert Into 语句批量生成器

    根据表格数据批量生成Insert Into语句 <br> 本人在登陆CSDN论坛的数据库板块时,常看到很多网友提关于数据库的各种问题。而这些问题中有很多是要使用范例数据的。但是很多提问的朋友却没有把这些范例数据库的...

    解析SQL语句中Replace INTO与INSERT INTO的不同之处

    在SQL语句中,`REPLACE INTO` 和 `INSERT INTO` 都是用来向数据库表中添加数据的命令,但它们之间存在重要的区别。本文将详细阐述这两种操作的区别以及使用场景。 首先,`INSERT INTO` 是最常用的插入数据的方式。...

    select into和insert into select使用方法

    在数据库管理与操作中,`SELECT INTO`与`INSERT INTO SELECT FROM`是两种常见的用于复制或创建新表的方式。这两种语句虽然相似,但在实际使用场景中有着不同的作用和限制条件。 #### 1. `SELECT INTO` `SELECT ...

    insert into

    "Insert Into"是SQL语言中的一个关键操作,用于向数据库表中插入新的数据记录。这个命令的基本语法结构是`INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...);`,其中`table_name`是你要...

    mssql insert into 和insert into select性能比较

    根据提供的描述,一次插入1190条数据时,使用 `INSERT INTO...VALUES` 需要大约510毫秒,而使用 `INSERT INTO...SELECT` 只需约16毫秒,这表明在处理大量数据时,`INSERT INTO...SELECT` 的性能显著优于 `INSERT ...

    SQL_INSERT_INTO_语句

    SQL_INSERT_INTO_语句是SQL语言中用于向数据库表中添加新记录的关键命令。它允许用户在已存在的表格中插入一行或多行新的数据。在理解这个语句之前,我们需要了解SQL(Structured Query Language),它是用于管理和...

    INSERT INTO SELECT语句与SELECT INTO FROM语句的一些区别

    1.INSERT INTO SELECT语句 语句形式为:Insert into Table2(field1,field2,…) select value1,value2,… from Table1 要求目标表Table2必须存在,由于目标表Table2已经存在,所以我们除了插入源表Table1的字段外,还...

    insert into select和select into的使用和区别介绍

    eg: 代码如下: insert into t2(id,name,pwd) select id,name,pwd from t1 注:t2必须存在。t1中查询的列名可不与t1列名相同。无 values select…into:查询t1中的数据,插入到t2中。 eg: 代码如下: select * into...

    SQL SERVER:把表里的数据导出成为INSERT INTO脚本的存储过程

    根据提供的文件信息,我们可以构建一个详细的SQL Server存储过程来实现将表中的数据转换为`INSERT INTO`脚本的功能。此存储过程将适用于多种数据类型,并能够动态生成插入语句,以便用户可以方便地导出数据作为脚本...

    MYSQL SELECT INTO 和 INSERT INTO SELECT

    ### MySQL中的SELECT INTO和INSERT INTO SELECT详解 #### 一、引言 在数据库管理与应用开发过程中,数据的复制是一项非常常见的需求。特别是在进行数据迁移、备份或创建新表时,能够快速有效地复制数据是非常重要...

    select into 和 insert into select 两种表复制语句

    第二句:INSERT INTO [ToTable] ([fild_One],[fild_Two]) SELECT [fild_One], 8 FROM [FromTable] 以上两句都是将 [FromTable] 的数据插入到 [ToTable],但两句又有区别的: 第一句(SELECT INTO FROM)要求目标表...

    解析MySQL中INSERT INTO SELECT的使用

    INSERT INTO db1_name(field1, field2) VALUES SELECT field1, field2 FROM db2_name ``` MySQL将会返回语法错误,正确的方式应该是直接使用`SELECT`: ```sql INSERT INTO db1_name(field1, field2) SELECT ...

    insert data into labview

    `Insert data into labview.vi` 就是一个VI,它的功能是导入Excel数据。 2. **数据类型**:LabVIEW中的数据以图标的形式表示,称为数据节点。对于Excel数据,我们需要使用字符串或数组类型来处理。 3. **Excel文件...

    Oracle 10g SQL操作.zip

    INSERT INTO departments VALUES(103,'机电工程','3号教学楼'); 连接查询时使用: INSERT INTO departments VALUES(104,'工商管理','4号教学楼'); 例3.3_21 添加teachers记录 教师记录: INSERT INTO teachers ...

    MySQL Insert Into 添加数据.docx

    MySQL Insert Into 添加数据 MySQL Insert Into 语句用于向数据表中添加数据记录。Insert Into 语句的基本语法是:INSERT INTO tb_name VALUES (value1, value2,...)。这个语法表示向表中所有的字段按顺序都插入...

    SELECT INTO 和 INSERT INTO SELECT 两种表复制语句详解(SQL数据库和Oracle数据库的区别)

    在SQL中,表复制是常见的数据操作,主要通过两种语句来实现:`SELECT INTO` 和 `INSERT INTO SELECT`。这两种语句在SQL数据库和Oracle数据库中略有不同,下面将详细解析它们的工作原理和使用场景。 1. `INSERT INTO...

Global site tag (gtag.js) - Google Analytics