SQl 跨服务器查询语句和跨数据创建表
2011-02-25 12:11
429 查看
select * from OPENDATASOURCE(
'SQLOLEDB',
'Data Source=远程ip;User ID=sa;Password=密码'
).库名.dbo.表名
insert 本地库名..表名 select * from OPENDATASOURCE(
'SQLOLEDB',
'Data Source=远程ip;User ID=sa;Password=密码'
).库名.dbo.表名
或使用联结服务器:
--创建linkServer
exec sp_addlinkedserver '别名','','SQLOLEDB','192.168.2.5'
--登陆linkServer
exec sp_addlinkedsrvlogin '别名','false',null,'sa','1234'
--查询
select * from 别名.库名.dbo.表名
--以后不再使用时删除链接服务器
exec sp_dropserver '别名','droplogins'
1.INSERT INTO SELECT语句
语句形式为:Insert into Table2(field1,field2,...) select value1,value2,... from Table1
要求目标表Table2必须存在,由于目标表Table2已经存在,所以我们除了插入源表Table1的字段外,还可以插入常量。示例如下:
--1.创建测试表
create TABLE Table1
(
a varchar(10),
b varchar(10),
c varchar(10),
CONSTRAINT [PK_Table1] PRIMARY KEY CLUSTERED
(
a ASC
)
) ON [PRIMARY]
create TABLE Table2
(
a varchar(10),
c varchar(10),
d int,
CONSTRAINT [PK_Table2] PRIMARY KEY CLUSTERED
(
a ASC
)
) ON [PRIMARY]
GO
--2.创建测试数据
Insert into Table1 values('赵','asds','90')
Insert into Table1 values('钱','asds','100')
Insert into Table1 values('孙','asds','80')
Insert into Table1 values('李','asds',null)
GO
select * from Table2
--3.INSERT INTO SELECT语句复制表数据
Insert into Table2(a, c, d) select a,c,5 from Table1
GO
--4.显示更新后的结果
select * from Table2
GO
--5.删除测试表
drop TABLE Table1
drop TABLE Table2
2.SELECT INTO FROM语句
语句形式为:SELECT vale1, value2 into Table2 from Table1
要求目标表Table2不存在,因为在插入时会自动创建表Table2,并将Table1中指定字段数据复制到Table2中。示例如下:
--1.创建测试表
create TABLE Table1
(
a varchar(10),
b varchar(10),
c varchar(10),
CONSTRAINT [PK_Table1] PRIMARY KEY CLUSTERED
(
a ASC
)
) ON [PRIMARY]
GO
--2.创建测试数据
Insert into Table1 values('赵','asds','90')
Insert into Table1 values('钱','asds','100')
Insert into Table1 values('孙','asds','80')
Insert into Table1 values('李','asds',null)
GO
--3.SELECT INTO FROM语句创建表Table2并复制数据
select a,c INTO Table2 from Table1
GO
--4.显示更新后的结果
select * from Table2
GO
--5.删除测试表
drop TABLE Table1
drop TABLE Table2
以下是采用Select Into 语句
跨数据库复制表实例:
select * into t_GroupsPermissions2 from (
select ID,1 as GroupID,17 as OrganizationID,PermissionID,note,getdate() as CreateTime from OpenDataSource(
'SQLOlEDB',
'Data Source=hn.sellingticket.com,2433;User ID=kan_li;Password=197001'
).hnnew.dbo.t_GroupsPermissions2 where OrganizationID=94) as t
'SQLOLEDB',
'Data Source=远程ip;User ID=sa;Password=密码'
).库名.dbo.表名
insert 本地库名..表名 select * from OPENDATASOURCE(
'SQLOLEDB',
'Data Source=远程ip;User ID=sa;Password=密码'
).库名.dbo.表名
或使用联结服务器:
--创建linkServer
exec sp_addlinkedserver '别名','','SQLOLEDB','192.168.2.5'
--登陆linkServer
exec sp_addlinkedsrvlogin '别名','false',null,'sa','1234'
--查询
select * from 别名.库名.dbo.表名
--以后不再使用时删除链接服务器
exec sp_dropserver '别名','droplogins'
SELECT INTO 和 INSERT INTO SELECT 两种表复制语句
Insert是T-sql中常用语句,Insert INTO table(field1,field2,...) values(value1,value2,...)这种形式的在应用程序开发中必不可少。但我们在开发、测试过程中,经常会遇到需要表复制的情况,如将一个table1的数据的部分字段复制到table2中,或者将整个table1复制到table2中,这时候我们就要使用SELECT INTO 和 INSERT INTO SELECT 表复制语句了。1.INSERT INTO SELECT语句
语句形式为:Insert into Table2(field1,field2,...) select value1,value2,... from Table1
要求目标表Table2必须存在,由于目标表Table2已经存在,所以我们除了插入源表Table1的字段外,还可以插入常量。示例如下:
--1.创建测试表
create TABLE Table1
(
a varchar(10),
b varchar(10),
c varchar(10),
CONSTRAINT [PK_Table1] PRIMARY KEY CLUSTERED
(
a ASC
)
) ON [PRIMARY]
create TABLE Table2
(
a varchar(10),
c varchar(10),
d int,
CONSTRAINT [PK_Table2] PRIMARY KEY CLUSTERED
(
a ASC
)
) ON [PRIMARY]
GO
--2.创建测试数据
Insert into Table1 values('赵','asds','90')
Insert into Table1 values('钱','asds','100')
Insert into Table1 values('孙','asds','80')
Insert into Table1 values('李','asds',null)
GO
select * from Table2
--3.INSERT INTO SELECT语句复制表数据
Insert into Table2(a, c, d) select a,c,5 from Table1
GO
--4.显示更新后的结果
select * from Table2
GO
--5.删除测试表
drop TABLE Table1
drop TABLE Table2
2.SELECT INTO FROM语句
语句形式为:SELECT vale1, value2 into Table2 from Table1
要求目标表Table2不存在,因为在插入时会自动创建表Table2,并将Table1中指定字段数据复制到Table2中。示例如下:
--1.创建测试表
create TABLE Table1
(
a varchar(10),
b varchar(10),
c varchar(10),
CONSTRAINT [PK_Table1] PRIMARY KEY CLUSTERED
(
a ASC
)
) ON [PRIMARY]
GO
--2.创建测试数据
Insert into Table1 values('赵','asds','90')
Insert into Table1 values('钱','asds','100')
Insert into Table1 values('孙','asds','80')
Insert into Table1 values('李','asds',null)
GO
--3.SELECT INTO FROM语句创建表Table2并复制数据
select a,c INTO Table2 from Table1
GO
--4.显示更新后的结果
select * from Table2
GO
--5.删除测试表
drop TABLE Table1
drop TABLE Table2
以下是采用Select Into 语句
跨数据库复制表实例:
select * into t_GroupsPermissions2 from (
select ID,1 as GroupID,17 as OrganizationID,PermissionID,note,getdate() as CreateTime from OpenDataSource(
'SQLOlEDB',
'Data Source=hn.sellingticket.com,2433;User ID=kan_li;Password=197001'
).hnnew.dbo.t_GroupsPermissions2 where OrganizationID=94) as t
相关文章推荐
- SQl 跨服务器查询语句和跨数据创建表
- SQl 跨服务器查询语句和跨数据创建表
- SQL高级语句-CREATE INDEX 在表中创建索引,以便更加快速高效地查询数据。
- 跨服务器查询导入数据的sql语句
- 跨服务器查询导入数据的sql语句
- 【黑马Android】(04)数据库的创建和sql语句增删改查/LinearLayout展示列表数据/ListView的使用和BaseAdater/内容提供者创建
- sql语句查询某字段中包含指定字符串的数据列表,完全匹配字段中逗号中间的字符串数据
- 跨服务器导入数据SQL语句
- mysql查询当天所有数据sql语句
- sql server2008中怎样用sql语句创建数据库和数据表
- 【SQL】SQL中的数据查询语句汇总
- 查询表中相同数据的sql语句[转]
- 如何用SQL语句查询Excel数据?
- mysql的sql语句中直接计算时间 查询昨天 一周前 一月前 一年前的数据的方法
- 10万数据量的数据库查询效率比较 纯sql语句 和 view 视图
- 安卓开发SQlite使用执行SQL语句一些简单的处理——2.查询数据库的数据
- SQL语句返回多表联合查询的结果集的数据条数
- 数据库SQL语句:查询一张表中某字段重复的数据
- 在sql语句随机查询几条数据 sql newid()随机函数
- 跨服务器导入数据SQL语句及其问题解决方案