加入收藏 | 设为首页 | 会员中心 | 我要投稿 拼字网 - 核心网 (https://www.hexinwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

server不同服务器复制表 sql

发布时间:2022-12-05 14:31:44 所属栏目:MsSql教程 来源:网络
导读: 如何用sqlserver语句复制一张表
1、复制表结构及数据到新表
CREATE TABLE 新表 SELECT * FROM 旧表
这种方法会将oldtable中所有的内容都拷贝过来,当然我们可以用delete from newtable;来删

如何用sqlserver语句复制一张表

1、复制表结构及数据到新表

CREATE TABLE 新表 SELECT * FROM 旧表

这种方法会将oldtable中所有的内容都拷贝过来,当然我们可以用delete from newtable;来删除。

不过这种方法的一个最不好的地方就是新表中没有了旧表的primary key、Extra(auto_increment)等属性。需要自己用"alter"添加,而且容易搞错。

2、只复制表结构到新表

CREATE TABLE 新表 SELECT * FROM 旧表 WHERE 1=2

或CREATE TABLE 新表 LIKE 旧表

3、复制旧表的数据到新表(假设两个表结构一样)

INSERT INTO 新表 SELECT * FROM 旧表

4、复制旧表的数据到新表(假设两个表结构不一样)

INSERT INTO 新表(字段1,字段2,…) SELECT 字段1,字段2,… FROM 旧表

5、可以将表1结构复制到表2

SELECT * INTO 表2 FROM 表1 WHERE 1=2

6、可以将表1内容全部复制到表2

SELECT * INTO 表2 FROM 表1

7、show create table 旧表;

这样会将旧表的创建命令列出。我们只需要将该命令拷贝出来,更改table的名字,就可以建立一个完全一样的表

场景 高版本的库这么同步到低版本库

using 低版本库

– 创建链接服务器

exec sp_addlinkedserver ‘ITSV’ , ‘’ , ‘SQLOLEDB’ , ‘.\MSSQLSERVER2014’

exec sp_addlinkedsrvlogin ‘ITSV’ , ‘false’ , null , 'sa ’ , ‘1密码’

– 查询示例

select top 10 * from ITSV.[Spider].[dbo].A

– 导入示例

select * into [SpiderWorld] from ITSV.[520musSpider].[dbo].A

不同数据库之间复制表的数据的方法:

当表目标表存在时:

insert into 目的数据库…表 select * from 源数据库…表

当目标表不存在时:

select * into 目的数据库…表 from 源数据库…表

–如果在不同的SQL之间:

insert into openrowset(‘sqloledb’,‘目的服务器名’;‘sa’;’’,目的数据库.dbo.表)

select * from 源数据库…表

– 创建链接服务器

exec sp_addlinkedserver ’ ITSV ’ , ’ ’ , ’ SQLOLEDB ’ , ’ 远程服务器名或ip地址 ’

exec sp_addlinkedsrvlogin ’ ITSV ’ , ’ false ’ , null , ’ 用户名 ’ , ’ 密码 ’

– 查询示例

select * from ITSV.数据库名.dbo.表名

– 导入示例

select * into 表 from ITSV.数据库名.dbo.表名

– 以后不再使用时删除链接服务器

exec sp_dropserver ’ ITSV ’ , ’ droplogins ’

– 连接远程/局域网数据(openrowset/openquery/opendatasource)

– 1、openrowset

– 查询示例

select * from openrowset ( ’ SQLOLEDB ’ , ’ sql服务器名 ’ ; ’ 用户名 ’ ; ’ 密码 ’ ,数据库名.dbo.表名)

– 生成本地表

select * into 表 from openrowset ( ’ SQLOLEDB ’ , ’ sql服务器名 ’ ; ’ 用户名 ’ ; ’ 密码 ’ ,数据库名.dbo.表名)

– 把本地表导入远程表

insert openrowset ( ’ SQLOLEDB ’ , ’ sql服务器名 ’ ; ’ 用户名 ’ ; ’ 密码 ’ ,数据库名.dbo.表名)

select * from 本地表

– 更新本地表

update b

set b.列A = a.列A

from openrowset ( ’ SQLOLEDB ’ , ’ sql服务器名 ’ ; ’ 用户名 ’ ; ’ 密码 ’ ,数据库名.dbo.表名) as a inner join 本地表 b

on a.column1 = b.column1

– openquery用法需要创建一个连接

– 首先创建一个连接创建链接服务器

exec sp_addlinkedserver ’ ITSV ’ , ’ ’ , ’ SQLOLEDB ’ , ’ 远程服务器名或ip地址 ’

– 查询

select *

FROM openquery (ITSV, ’ SELECT * FROM 数据库.dbo.表名 ’ )

– 把本地表导入远程表

insert openquery (ITSV, ’ SELECT * FROM 数据库.dbo.表名 ’ )

select * from 本地表

– 更新本地表

update b

set b.列B = a.列B

FROM openquery (ITSV, ’ SELECT * FROM 数据库.dbo.表名 ’ ) as a

inner join 本地表 b on a.列A = b.列A

– 3、opendatasource/openrowset

SELECT *

FROM opendatasource ( ’ SQLOLEDB ’ , ’ Data Source=ip/ServerName;User ID=登陆名;Password=密码 ’ ).test.dbo.roy_ta

– 把本地表导入远程表

insert opendatasource ( ’ SQLOLEDB ’ , ’ Data Source=ip/ServerName;User ID=登陆名;Password=密码 ’ ).数据库.dbo.表名

select * from

注意:某些时候会出现未开启Ad Hoc,使用下面的语句开启使用

启用Ad Hoc Distributed Queries:

exec sp_configure ‘show advanced options’,1

reconfigure

exec sp_configure ‘Ad Hoc Distributed Queries’,1

reconfigure

使用完成后,关闭Ad Hoc Distributed Queries:

exec sp_configure ‘Ad Hoc Distributed Queries’,0

reconfigure

exec sp_configure ‘show advanced options’,0

reconfigure

好吧,如果上面看得烦下面有个更容易理解的例子:

Exec sp_droplinkedsrvlogin DBVIP,Null

Exec sp_dropserver DBVIP

EXEC sp_addlinkedserver

@server=‘DBVIP’,–被访问的服务器别名

@srvproduct=’’,

@provider=‘SQLOLEDB’,

@datasrc=‘Server2’ --要访问的服务器

EXEC sp_addlinkedsrvlogin

‘DBVIP’, --被访问的服务器别名

‘false’,

NULL,

‘sa’, --帐号

‘thankyoubobby’ --密码

Select * from DBVIP.pubs.dbo.orders

/ORACLE

Exec sp_droplinkedsrvlogin demo,Null

Exec sp_dropserver demo

go

EXEC sp_addlinkedserver

@server =‘demo’,

@srvproduct=‘Oracle’,

@provider=‘MSDAORA’,

@datasrc=‘ServiceName’

EXEC sp_addlinkedsrvlogin

‘demo’,

‘false’,

NULL,

‘userid’,

‘password’

go

SELECT * FROM OPENQUERY(demo ,‘select * from tbdemo’ )

UPDATE OPENQUERY (demo, ‘SELECT id FROM tbdemo WHERE id = 101’)

SET name = ‘hello’;

INSERT OPENQUERY (demo, ‘SELECT id FROM tbdemo’)

VALUES (‘hello’);

DELETE OPENQUERY (demo, ‘SELECT id FROM tbdemo WHERE name = ‘‘hello’’’);

-------------------------------------------具体例子------------------------------------------------------------

if exists(select 1 from master.dbo.sysservers where srvname = ‘test’)

begin

exec sp_droplinkedsrvlogin ‘test’,‘sa’

exec sp_dropserver ‘test’

end

–建立连接服务器

EXEC sp_addlinkedserver ‘test’, ‘ms’,‘SQLOLEDB’, ‘192.168.1.99’

exec sp_addlinkedsrvlogin ‘test’,‘false’,null,‘sa’,’’

select * from test.db_film.dbo.T_film

go

if exists(select 1 from master.dbo.sysservers where srvname = ‘test’)

begin

exec sp_droplinkedsrvlogin ‘test’,‘sa’

exec sp_dropserver ‘test’

end

go

方法二:

1、新建一个连接服务器,连接到你要导入的服务器的IP地址(或者机器名)

2、点击安全性,使用此安全上下文建立连接,输入数据库服务器的用户名和密码

3、选择要导出的数据库,使用如下sql导数据:

select * into laobao from [10.180.116.121].ynpdeicp.dbo.LaoBao

Sql解释:

select 要导入的字段 into 要导入的数据表 from [IP地址].数据库名.dbo.数据表名

大坑笔记 主键 自增 索引 相关

1.新建一数据表,里面有字段id,将id设为为主键

create table tb(id int,constraint pkid primary key (id))

create table tb(id int primary key )

2.新建一数据表,里面有字段idmssql复制表,将id设为主键且自动编号

create table tb(id int identity(1,1),constraint pkid primary key (id))

create table tb(id int identity(1,1) primary key )

3.已经建好一数据表,里面有字段id,将id设为主键

alter table tb alter column id int not null

alter table tb add constraint pkid primary key (id)

4.删除主键

Declare @Pk varChar(100);

Select @Pk=Name from sysobjects where Parent_Obj=OBJECT_ID(‘tb’) and xtype=‘PK’;

if @Pk is not null

exec('Alter table tb Drop '+ @Pk)

(编辑:拼字网 - 核心网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!