原文:怎样用sql语句复制表table1到表table2的同时复制主键


在从table1表复制到table2的时候,我们会用语句:

select * into table2 from table1

但这个语句并不能在复制数据的同时,复制主键。

下面的代码通过动态语句,来实现在复制数据的同时,也会复制主键:


  1. if OBJECT_ID('table1') is not null
  2. drop table table1
  3. go
  4. create table table1
  5. (
  6. id int ,
  7. idd int,
  8. vvv varchar(100),
  9. primary key (id,idd) --为了实验在主键有多个字段的情况,所有主键这里有2个字段
  10. )
  11. insert into table1
  12. select 1,1,'a' union all
  13. select 1,2,'b' union all
  14. select 2,1,'a'
  15. go
  16. declare @old_table_name varchar(30)
  17. declare @new_table_name varchar(30)
  18. declare @is_clustered varchar(10)
  19. declare @sql varchar(1000)
  20. set @old_table_name = 'table1';
  21. set @new_table_name = 'table2';
  22. set @is_clustered = '';
  23. set @sql = '';
  24. select @is_clustered = i.type_desc,
  25. @sql = @sql + ',' + c.name +
  26. case when ic.is_descending_key = 0
  27. then ' asc'
  28. else ' desc'
  29. end
  30. from sys.tables t
  31. inner join sys.indexes i
  32. on t.object_id = i.object_id
  33. inner join sys.index_columns ic
  34. on i.object_id = ic.object_id
  35. and i.index_id = ic.index_id
  36. inner join sys.columns c
  37. on c.column_id = ic.column_id
  38. and c.object_id = ic.object_id
  39. where i.is_primary_key = 1
  40. and t.name = @old_table_name
  41. order by key_ordinal
  42. select @sql = 'if object_id(''' + @new_table_name + ''') is not null' +
  43. ' drop table ' + @new_table_name +';' +
  44. 'select * into ' + @new_table_name +
  45. ' from ' + @old_table_name + ';' +
  46. 'alter table ' + @new_table_name +
  47. ' add primary key ' + @is_clustered +
  48. '(' + stuff(@sql,1,1,'') + ')'
  49. select @sql
  50. /*
  51. if object_id('table2') is not null
  52. drop table table2;
  53. select * into table2 from table1;
  54. alter table table2 add primary key CLUSTERED(id asc,idd asc)
  55. */
  56. exec(@sql)
  57. select *
  58. from table2
  59. /*
  60. id idd vvv
  61. 1 1 a
  62. 1 2 b
  63. 2 1 a
  64. */

发布了416 篇原创文章 · 获赞 135 · 访问量 94万+

怎样用sql语句复制表table1到表table2的同时复制主键的更多相关文章

  1. sql语句复制表

    1.复制表结构及数据到新表CREATE TABLE 新表 SELECT * FROM 旧表 这种方法会将oldtable中所有的内容都拷贝过来,当然我们可以用delete from newtable; ...

  2. Oracle和sql server中复制表结构和表数据的sql语句

    在Oracle和sql server中,如何从一个已知的旧表,来复制新生成一个新的表,如果要复制旧表结构和表数据,对应的sql语句该如何写呢?刚好阿堂这两天用到了,就顺便把它收集汇总一下,供朋友们参考 ...

  3. sql语句 怎么从一张表中查询数据插入到另一张表中?

    sql语句 怎么从一张表中查询数据插入到另一张表中?  ----原文地址:http://www.phpfans.net/ask/MTc0MTQ4Mw.html 比如我有两张表 table1 字段 un ...

  4. SQL语句分组排序,多表关联排序

    SQL语句分组排序,多表关联排序总结几种常见的方法: 案例一: 在查询结果中按人数降序排列,若人数相同,则按课程号升序排列? 分析:单个表内的多个字段排序,一般可以直接用逗号分割实现. select ...

  5. sql语句,怎么查看一个表中的所有约束

    sql语句,怎么查看一个表中的所有约束,比如,一个student表,有唯一,外键,主键,用sql语句怎么查看student表中的所有约束呢? select * from sysobjects wher ...

  6. SQL语句获取数据库中的表主键,自增列,所有列

    SQL语句获取数据库中的表主键,自增列,所有列   获取表主键 1:SELECT TABLE_NAME,COLUMN_NAME FROM INFORMATION_SCHEMA.KEY_COLUMN_U ...

  7. sql语句建表,并且自增加主键

    sql语句建表,并且自增加主键 use [test] CREATE TABLE [dbo].[Table_4] ( [userid] [int] IDENTITY(1,1) NOT NULL, CON ...

  8. Sql Server 复制表

    SELECT INTO 和 INSERT INTO SELECT 两种表复制语句 1.INSERT INTO SELECT语句 语句形式为:Insert into Table2(field1,fiel ...

  9. SQL语句汇总(一)——数据库与表的操作以及创建约束

    首先,非常感谢大家对上篇博文的支持,真是让本菜受宠若惊,同时对拖了这么久才出了此篇表示抱歉. 前言:此文旨在汇总从建立数据库到联接查询等绝大部分SQL语句.SQL语句虽不能说很多,但稍有时间不写就容易 ...

随机推荐

  1. qt mvc3

    前面两节讲的model是一维的,这次开始二维的也就是我们常说的Table,相对与list,我们多了一个列的概念. 下面讲解一个例子.我先说明一下我们这个例子,在程序目录下,我们有一个文本文件,其中存放 ...

  2. Discretized Streams: A Fault-Tolerant Model for Scalable Stream Processing

    https://www2.eecs.berkeley.edu/Pubs/TechRpts/2012/EECS-2012-259.pdf Discretized Streams: A Fault-Tol ...

  3. 关于python环境下的opencv安装

    吐槽: 这一天我终于记起了这个博客.今天搞python环境下的opencv,又弄了一天,很烦躁.之前配置VS的opencv也是花了好久的时间,然后突然发现之前记录在电脑上的文档都找不到了,于是决定还是 ...

  4. IO流概述

    作用: 处理设备之间的数据传输的 I: Input(输入) , O: Output(输出) 什么是输入和输出? 我们说输入和输出问题是站在内存的角度而言 , 如果我们程序读取硬盘上的数据那么就是输入 ...

  5. Java 8 Steam 例子整理

    Java 8 Steam 例子整理 kexue 关注 2016.06.06 17:44* 字数 1860 阅读 3901评论 0喜欢 6 IBM: Java 8 中的 Streams API 详解 为 ...

  6. Python检查数组元素是否存在类似PHPisset()方法

    Python检查数组元素是否存在类似PHP isset()方法 sset方法来检查数组元素是否存在,在Python中无对应函数,在Python中一般可以通过异常来处理数组元素不存在的情况,而无须事先检 ...

  7. Jsoup-基础练习

    认识Jsoup 一个解析网页的工具 无论你用什么语言爬虫,都要解析网页,今天,我们用一款常用的网页解析Jsoup,来开启爬虫的第一课 认识网页,认识爬虫,认识你自己 *** 快速上手 了解一个新东西最 ...

  8. 【Leetcode_easy】812. Largest Triangle Area

    problem 812. Largest Triangle Area solution: class Solution { public: double largestTriangleArea(vec ...

  9. 【Leetcode_easy】766. Toeplitz Matrix

    problem 766. Toeplitz Matrix solution1: class Solution { public: bool isToeplitzMatrix(vector<vec ...

  10. (CVE-2015-0240)Samba远程代码执行

    简介 Samba 是利用 SMB 协议实现文件共享的一款著名开源工具套件.日前 Samba 曝出一个严重安全漏洞,该漏洞出现在 smbd 文件服务端,漏洞编号为 CVE-2015-0240,可以允许攻 ...