sql复制表结构和数据的实现方法

所属分类: 数据库 / MsSql 阅读数: 331
收藏 0 赞 0 分享

SQL SERVER中使用SELECT … INTO语句

按照使用场合可以分为以下几类:

1. 实现全表备份:如:SELECT * INOT t1 FROM titles

2. 备份表的一部分列(不写*而写出列的列表)或一部分行(加WHERE条件)

如:

SELECT title_id,title,price INTO t2 FROM titles—部分列 
SELECT * INTO t2 FROM titles WHREE price>10 –部分行 
SELECT title_id,title,price INTO t2 FROM titles WHREE price>10 –部分行和部分列 

3. 只复制表的结构:

SELECT * INTO tablename_new FROM tablename_old

如:SELECT * INOT t1 FROM titles WHERE 1=2

4. 查询结果来源于多个表:如:

SELECT title_id,title,pub_name INTO t3 
FROM titles t INNER JOIN publishers p 
ON t.pub_id=p.pub_id 

5.select * into 要复制到的数据库名.DBO.表名 from 原数据库名.DBO.表名

从news表复制指定字段到news1

set IDENTITY_INSERT [dbo].[news1] ON
INSERT INTO [dbo].[news1] ([id],[title],[stitle],[type_id],[scontent],[keyword],[tag],[author]) SELECT [id],[title],[stitle],[type_id],[scontent],[keyword],[tag],[author] 

FROM [dbo].[news]
set IDENTITY_INSERT [dbo].[news1] OFF

2.从news表复制id,content字段到content_1(id指定区间)

create table content_1([id] [int] primary key NOT NULL, [content] [text] NULL)
INSERT INTO [dbo].[content_1] ([id],[content] ) SELECT [id],[content] FROM [dbo].[news] where [id] between 1 and 100000
create table content_2([id] [int] primary key NOT NULL, [content] [text] NULL)
INSERT INTO [dbo].[content_2] ([id],[content] ) SELECT [id],[content] FROM [dbo].[news] where [id] between 100001 and 200000
create table content_3([id] [int] primary key NOT NULL, [content] [text] NULL)
INSERT INTO [dbo].[content_3] ([id],[content] ) SELECT [id],[content] FROM [dbo].[news] where [id] > 200000

数据库 复制表

数据库把一张表完整无缺的复制到另外一张表中

简单的 :

insert into 目标表 select * from 原表;

(两张表结构必须相同 ,这种方法限制太多)

推荐

虽然文字多 ,但还是很明白的,一看就会
1、鼠标右击要复制的表,选择“编写表脚本为”>“CREATE到”>“新建查询编辑器窗口”命令
2、 在查询编辑器窗口中将要复制表的名称修改为新表的名称。
3、修改表名称后,单击“执行”按钮,即可完成新表的表结构创建。
4、 右击“表”选项,选择“刷新”命令,即可看到新创建的表。
5、 右击新创建的表,选择“编写表脚本为”>“INSERT到”>“新建查询编辑器窗口”命令。
6、 在打开的查询编辑器窗口中输入表数据复制代码,然后单击“执行”按钮。
7、打开新创建的表,这时可以看到已经将源表中的结构和数据复制过来。

SqlServer 复制表结构与复制数据

1、复制表结构

select [col1,col2,col3...] into new_table 
from old_table where 1=1 ;

一般都是

SELECT * INTO tablename_new FROM tablename_old

2、复制数据

insert into table1(col1,col2,col3,...) 
select [col1,col2,col3...] from table2 ;

这样比图文方法要简单多了,效率也高。

更多精彩内容其他人还在看

浅析SQL Server 聚焦索引对非聚集索引的影响

本篇文章对SQL Server的聚焦索引和非聚集索引进行简单分析,从而总结出聚焦索引对非聚集索引的影响。有兴趣的朋友可以看下
收藏 0 赞 0 分享

浅析SQL Server的聚焦使用索引和查询执行计划

本文通过介绍默认使用索引、强制使用聚集索引、强制使用非聚集索引让我们知道对于检索所有列结果集使用主键的聚集索引是最佳选择。有兴趣的朋友可以看下
收藏 0 赞 0 分享

详解SQL Server中的数据类型

本文主要讲解了SQL中的数据类型以及几个需要注意的地方,简短的内容,深入的理解。有兴趣的朋友可以看下
收藏 0 赞 0 分享

浅析SQL Server的分页方式 ISNULL与COALESCE性能比较

本文上述重点讲述了SQL Server的分页方式,COALESCE和ISNULL函数区别之处,简短的内容,深入的理解。有兴趣的朋友可以看下
收藏 0 赞 0 分享

浅述SQL Server的聚焦强制索引查询条件和Columnstore Index

本文主要讲了强制使用索引条件来进行查询,当对于使用默认创建索引进行查询计划时觉得不是最优解,可以尝试使用强制索引来进行对比找出更好得解决方案。简短的内容,深入的理解.有兴趣的朋友可以看下
收藏 0 赞 0 分享

详解SQL Server的聚焦过滤索引

本文主要讲解了通过过滤索引来提高查询性能,同时也给出了其不同的场景以及其使用优点和明显的缺点。简短的内容,深入的理解,有兴趣的朋友可以看下
收藏 0 赞 0 分享

解析SQL Server聚焦移除(Bookmark Lookup、RID Lookup、Key Lookup)

本文主要讲解索引性能优化,着重对Bookmark Lookup、RID Lookup、Key Lookup三者进行移除的实现进行解析,以此来提高查询性能。希望对大家有所帮助
收藏 0 赞 0 分享

SqlServer 注释符 单行注释与多行注释

这篇文章主要介绍了SqlServer 注释符 单行注释与多行注释,需要的朋友可以参考下
收藏 0 赞 0 分享

SQL设置SQL Server最大连接数及查询语句

今天遇到了关于Sql Server最大连接数(Max Pool Size)的问题,后来通过查找一些资料解决了,所以想着总结下关于SQL Server最大连接数的内容,所以这篇文章主要介绍了SQL设置SQL Server最大连接数与查询语句,有需要的朋友们可以参考借鉴。
收藏 0 赞 0 分享

浅谈SQL Server交叉联接 内部联接

本文主要讲了SQL Server的交叉联接和内部联接,同时也给出了使用需要注意的地方。有需要的朋友可以看下
收藏 0 赞 0 分享
查看更多