Move row from one table to another?
Asked Answered
T

5

17

I have two tables with the same column definitions. I need to move (not copy) a row from one table to another. Before I go off and use INSERT INTO/DELETE (in a transaction), is there a smarter way?

SQL Server 2005

Trilbie answered 13/5, 2010 at 19:11 Comment(0)
H
32

for SQL Server 2005 and up, try the OUTPUT Clause (Transact-SQL) clause:

DELETE OldTable
  OUTPUT DELETED.col1, DELETED.col2...
      INTO NewTable
  WHERE ID=...

Working example:

DECLARE @OldTable table(col1 int, col2    varchar(5), col3 char(5), col4     datetime)
DECLARE @NewTable table(col1 int, column2 varchar(5), col3 int    , col_date char(23), extravalue int, othervalue varchar(5))
INSERT @OldTable VALUES (1 , 'AAA' ,'A'  ,'1/1/2010'           )
INSERT @OldTable VALUES (2 , 'BBB' ,'12' ,'2010-02-02 10:11:22')
INSERT @OldTable VALUES (3 , 'CCC' ,null ,null                 )
INSERT @OldTable VALUES (4 , 'B'   ,'bb' ,'2010-03-02'         )

DELETE @OldTable
    OUTPUT DELETED.col1
          ,DELETED.col2
          ,CASE
               WHEN ISNUMERIC(DELETED.col3)=1 THEN DELETED.col3 
               ELSE NULL END
          ,DELETED.col4
          ,CONVERT(varchar(5),DELETED.col1)+'!!'
        INTO @NewTable (col1, column2, col3, col_date, othervalue)
    OUTPUT 'Rows Deleted: ', DELETED.* --this line returns a result set shown in the OUTPUT below
    WHERE col1 IN (2,4)

SELECT * FROM @NewTable

OUTPUT:

               col1        col2  col3  col4
-------------- ----------- ----- ----- -----------------------
Rows Deleted:  2           BBB   12    2010-02-02 10:11:22.000
Rows Deleted:  4           B     bb    2010-03-02 00:00:00.000

(2 row(s) affected)

col1        column2 col3        col_date                extravalue  othervalue
----------- ------- ----------- ----------------------- ----------- ----------
2           BBB     12          Feb  2 2010 10:11AM     NULL        2!!
4           B       NULL        Mar  2 2010 12:00AM     NULL        4!!

(2 row(s) affected)
Handler answered 13/5, 2010 at 19:14 Comment(8)
@KM: +1. I was not aware of this. Would you recommend this method over INSERT and DELETE?Lebkuchen
I would use this over an INSERT and a DELETE every time, SQL Server can probably optimize it better and it guarantees you INSERT and DELETE only the same rows, no more and no less.Handler
This is one statement, so... no transaction necessary, I guess?Trilbie
@lance, unless you have other database changes that you want to tie to this command, then no.Handler
@lance, I've added a working example, if that doesn't answer your question, provide more specifics on the columns in the tables that are having questions about.Handler
I'm in great shape. It was an absolute long shot, my asking this question. I just thought I'd ask the smart people before doing "what I know". It's so satisfying getting such a great answer, and it's even more satisfying seeing the multiple other people who thought as I did and have learned this "new" technique from my question. Thanks so very much.Trilbie
@Handler This topic is a bit old, but if you need to move the row w/o one of the columns and add in a new column, would you still suggest using this?Osric
@Max, If you need to capture deleted rows, there is no better way than using OUTPUT. If you need another column I'd UPDATE and join it on after having the populated the rows with the DELETE OUTPUT.Handler
C
3

You can try Insert into abc (a,b,c) select(a,b,c) from def

doing above so will insert column a, b,c of def into column a,b,c of abc. after inserting run a delete table, drop table or truncate whatever is your criteria.

sample is:

Begin
    Begin try

         Begin Transaction

               Insert into emp(name, department, salary)                    
                       Select empName,empDepartment,empSal from employees
                       Where  employees.empID = 211

               Truncate table employees

          End Transaction  

    End try

    Begin Catch

         if @@Error > 0
              Rollback Transaction

    End Catch

End
Coon answered 13/5, 2010 at 19:39 Comment(0)
D
0

There is no such thing as a MOVE command in SQL. You'll have to first insert from table 1 to table 2 Then remove the copy from table 1.

Doggett answered 13/5, 2010 at 19:13 Comment(1)
OP is using SQL Server 2005, so the OUTPUT Clause (Transact-SQL) can do it in a single command, see my answer...Handler
U
0

No, you are pretty much stuck with insert and delete wrapped inside a transaction

Unblock answered 13/5, 2010 at 19:13 Comment(1)
OP is using SQL Server 2005, so the OUTPUT Clause (Transact-SQL) can do it in a single command, see my answer...Handler
L
0
INSERT dbo.newtable(
      name,
      department,
      Salary
) SELECT 
            name,
            FirstName,
            Lastname
      FROM    (
           DELETE dbo.oldtable
           OUTPUT
                   DELETED.name,
                   DELETED.department,
                   DELETED.Salary
           WHERE ID  IN ( 1001, 1003, 1005 )
      ) AS RowsToMove  

SELECT * FROM dbo.newtable
SELECT * FROM dbo.oldtable
Landward answered 23/7, 2015 at 13:49 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.