zoukankan      html  css  js  c++  java
  • The typical scenarios of using "Insert" in Tsql

    1.The most common one
    INSERT INTO V1 (col1, col2)  VALUES ('Row 1',1);

    2.Sometimes you just need to insert a default row
    INSERT INTO T1 DEFAULT VALUES;

    3.What if you have a Identity column, and you still want to insert a row with you own value of that column?
    CREATE TABLE dbo.T1 ( column_1 int IDENTITY, column_2 VARCHAR(30));
    GO
    SET IDENTITY_INSERT T1 ON;
    GO
    INSERT INTO T1 (column_1,column_2)  VALUES (-99, 'Explicit identity value');

    4.What if the table that you want to insert has a uniqueidentifier column?
    CREATE TABLE dbo.T1
    (
        column_1 int IDENTITY,
        column_2 uniqueidentifier,
    );
    GO
    INSERT INTO dbo.T1 (column_2)  VALUES (NEWID());

    ------------------------------------------------------------------------------------------
    -- above are all the use of "INSERT INTO". Now let try the "INSERT...SELECT"
    ------------------------------------------------------------------------------------------

    5.most common "insert... select"
    insert T1
    select col1, col2 from T2

    6.like "select into", you can only set value for part of the columns
    insert test12(ItemID)
    select ItemID
    from test11 where ItemID=-6188872580015720368

    7.you can use EXEC if you want, to run a sp or string
    insert T1 exec('select col1, col2 from T2') -- run a query string
    insert T1 exec sp_YouSPName  -- run a sp

    8.two ways of top insert. I prefer the second one, and you?
    insert top (10) into test12 select * from test11
    insert test12 select top 10 * from test11

    -----------------------------------------------------------------------------
    --For above senarios, you all need to create a table before you insert rows into it
    --now let's see something different
    --------------------------------------------------------------------------------
    9.quick copy
    select * into T2 from T1  -- you don't need to create T2 before it

    10.quick create a empty table using the same schema with a existed table
    select * into T2 from T1 where 1=0

    --------------------------------------------------------------------------
    --What if we want to get some thing out of the new-inserted rows?
    --Like the value of a indentify column, or the value of some computed column?
    --------------------------------------------------------------------------------
    11. A simple example of 'Output'
    --ScrapReasonID is a IDENTITY column in Table 'ScrapReason'
    DECLARE @MyTableVar table( ScrapReasonID smallint,
                               Name varchar(50),
                               ModifiedDate datetime);
    GO
    INSERT Production.ScrapReason
        OUTPUT INSERTED.ScrapReasonID, INSERTED.Name, INSERTED.ModifiedDate
            INTO @MyTableVar

    VALUES (N'Operator error', GETDATE());

  • 相关阅读:
    MySql查询分页数据
    出现不不能引java.util.Date包的情况
    类的反射实例(servlet的抽取)
    关于C++ const 的全面总结
    教你用笔记本破解无线路由器password
    使用 HTML5 webSocket API实现即时通讯的功能
    用户研究经验分享
    我的学习笔记_Windows_HOOK编程 2009-12-03 11:19
    用户參与记录存储的演变
    IC芯片
  • 原文地址:https://www.cnblogs.com/xingyukun/p/1149829.html
Copyright © 2011-2022 走看看