持之以恒

          記錄本
          posts - 4, comments - 32, trackbacks - 0, articles - 74
            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

          日歷

          <2025年7月>
          293012345
          6789101112
          13141516171819
          20212223242526
          272829303112
          3456789

          隨筆分類

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

           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


          小白
          主站蜘蛛池模板: 治多县| 客服| 青阳县| 安龙县| 青川县| 诸暨市| 望谟县| 宁城县| 芜湖市| 九江县| 新郑市| 渝北区| 孝感市| 宁南县| 古丈县| 乐陵市| 松溪县| 抚松县| 四平市| 丹寨县| 明溪县| 黄骅市| 乐山市| 乌拉特后旗| 淅川县| 突泉县| 名山县| 乐清市| 大邑县| 涿州市| 金乡县| 泽库县| 苏尼特左旗| 临夏县| 巴林右旗| 平和县| 武夷山市| 南平市| 繁昌县| 太仆寺旗| 吕梁市|