Sqlserver
 sql >> डेटाबेस >  >> RDS >> Sqlserver

SQL - एक रिकॉर्ड और उसके वंशजों को क्लोन करें

जैसा कि मार्टिन ने सुझाव दिया था, आपको IDENTITY_INSERT . को सक्षम करने की आवश्यकता है ताकि आप अपने स्वयं के पहचान मूल्यों को आगे बढ़ा सकें। आपको यह सुनिश्चित करने के लिए टेबल लॉक प्राप्त करने की भी आवश्यकता हो सकती है कि मैक्स (आईडी) सही मान लौटाए।

If object_id('tempdb..#TestData') is not null
    Drop Table #TestData
GO
Create Table #TestData
    (
    Id int not null identity(1,1) Primary Key
    , ParentId int not null
    , Name varchar(50) not null
    )
GO
Set Identity_Insert #TestData On
GO  
Insert #TestData( Id, ParentId, Name )
Values( 1,0,'Food' )
    , ( 2,1,'Taste' )
    , ( 3,1,'Price' )
    , ( 4,2,'Taste Requirement' );


With Data As
    (
    Select Cast(MaxId.Id + 1 As int) As Id
        , T.ParentId
        , 'Copy Of ' + T.name As Name
        , T.Id As OldId
        , 0 As OldParentId
    From #TestData As T
        Cross Join( Select Max( id ) As Id From #TestData ) As MaxId
    Where T.Name = 'Food'
    Union All
    Select Cast(Parent.id + Row_Number() Over( Order By Child.Id ) + 1 As int)
        , Parent.Id
        , 'Copy of ' + Child.Name
        , Child.Id
        , Child.ParentId
    From Data As Parent
        Join #TestData As Child
            On Child.ParentId = Parent.OldId
    )
Insert #TestData( Id, ParentId, Name )
Select Id, ParentId, Name
From Data
GO
Set Identity_Insert #TestData Off
GO  

परिणाम

id | parentid | name
-- | -------- | -----------------
1  | 0        | Food
2  | 1        | Taste
3  | 1        | Price
4  | 2        | Taste Requirement
5  | 0        | Copy Of Food
7  | 5        | Copy of Taste
8  | 5        | Copy of Price
9  | 7        | Copy of Taste Requirement


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. SQL सर्वर चुनें जहां किसी भी कॉलम में 'x' होता है

  2. क्या SQL Server 2008 स्थानिक डेटा सुविधाएँ मैपिंग प्रश्नों के लिए उपयोगी हैं?

  3. SQL सर्वर ARITHABORT

  4. SQL सर्वर 2014 की खोज समानांतरवाद में चुनें

  5. MSSQL2008 - Pyodbc - पिछला SQL एक प्रश्न नहीं था