不同服务器中的两个表连接查询(SQLSERVER)
2011-02-27 22:12
701 查看
1,一个服务器中两个不同数据库的两个表查询
select * from 数据库1.表名 A,数据库2.表名 b on A.Id=B.Ids
2,同一库中两表或多表的查询方式
两表查询 select * from TB1 left join TB2 On tb1.where = tb2.where 或者 select * from TB1 ,TB2 where tb1.where = tb2.where
多表查询 select * from tb1 left join tb2 on tb1.where =tb2.where inner join tb3 on (tb3.wehre = tb2.where) inner join tb4.......................
cross join:是笛卡儿乘积,在没有任何条件约束下就是一张表的行数乘以别一张表的行数。
left join:返回“表名1”的全部行,对于“表名2”中,不满足on条件的记录用空值替换。
rigth join:返回“表名2”的全部行,对于“表名1”中,不满足on条件的记录用空值替换。
full join:返回两张表中的所有记录,对于不满足on条件一端的记录用空值替换。
inner jon:只返回两张表中都满足on条件的记录
2, SQL语句连接查询位于两个不同的服务器不同的数据库中的两个表
select * from Product p inner join
opendatasource('SQLOLEDB','Data Source=Macaco-Online;user ID=sa;password=sa密码;').Company.dbo.Product p2
on P.PID=p2.PID
go
执行时出现错误提示:
-----------------------------------------------------------------
消息 15281,级别 16,状态 1,第 1 行 SQL Server 阻止了对组件 'Ad Hoc Distributed Queries' 的 STATEMENT'OpenRowset/OpenDatasource' 的访问,因为此组件已作为此服务器安全配置的一部分而被关闭。系统管理员可以通过使用 sp_configure 启用 'Ad Hoc Distributed Queries'。有关启用 'Ad Hoc Distributed Queries' 的详细信息,请参阅 SQL Server 联机丛书中的 "外围应用配置器"。
-----------------------------------------------------------------
嗯 这个提示似乎很明确 从上面的提示我们可以知道只要启用外围应用配置器的Ad Hoc Distributed Queries组件即可 随即把自己机器上数据库服务器的外围应用配置器打开 找到Ad Hoc Distributed Queries组件并将其启用(启用步骤:右击自己的数据库服务器,在右键菜单中选择“方面” 在弹出的的窗口中有一个名为方面的下拉列表先项点开后选择“外围应用配置器”选项,然后在下面的方面属性窗口中将AdHocremoteQueriesEnabled的状态改成true点击确定即要可)
现在就可以执行上面的应该查询语句了。
这似乎并不能满足我们的需要
例如:我们要在自己的程序中做这样的的查询那该怎么办呢?总不能一直这样开着吧 这可是对服务器有安全损耗的 嗯 我可不会就这样把自己服务器的安全级别降低哦。
好吧 我们现在需要使用SQL命令来启用和禁用这个组件,但是怎么做呢? 不要急再分析一下上面出错时的提醒我们便可以知道使用SP_Configure便可以启用禁用这个组件了 现在改变我们的SQL命令如下所示:
exec sp_configure 'show advanced options',1
reconfigure
exec sp_configure 'Ad Hoc Distributed Queries',1
reconfigure
go
select * from Product p inner join
opendatasource('SQLOLEDB','Data Source=Macaco-Online;user ID=sa;password=sa密码;').Company.dbo.Product p2
on P.PID=p2.PID
go
exec sp_configure 'Ad Hoc Distributed Queries',0
reconfigure
exec sp_configure 'show advanced options',0
reconfigure
go
嗯 这样我们就可以在需要启用这样组件的时候启用即可(注:Ad Hoc Distributed Queries是高级配置所以需要先启用Show advanced options 也就是说无论你是要启用Ad Hoc Distributed Queries还是禁用都必须保证show advanced options为启用状态)有些朋友便疑惑了你这样又是存储过程又是SQL语句的我在程序里该执行什么类型的命令啊 呵呵 其实 SqlCommand对象执行命令时就象是我们用Microsoft SQL Server Management Studio新建了一个查询窗口一样在这个查询窗口里你可以执行什么 SqlCommand对象就可以执行什么 所以你只要将上面的sql命令中的换行符替换成空格组成一串字符串然后把他赋值给SqlCommand对象的CommadnTest属性 然后执行就可以了(哦 好像我还没有使用这种方法创建数据库 不过如果你连接数据库使用的用户权限足够的化应该也没有什么问题!)
select * from 数据库1.表名 A,数据库2.表名 b on A.Id=B.Ids
2,同一库中两表或多表的查询方式
两表查询 select * from TB1 left join TB2 On tb1.where = tb2.where 或者 select * from TB1 ,TB2 where tb1.where = tb2.where
多表查询 select * from tb1 left join tb2 on tb1.where =tb2.where inner join tb3 on (tb3.wehre = tb2.where) inner join tb4.......................
cross join:是笛卡儿乘积,在没有任何条件约束下就是一张表的行数乘以别一张表的行数。
left join:返回“表名1”的全部行,对于“表名2”中,不满足on条件的记录用空值替换。
rigth join:返回“表名2”的全部行,对于“表名1”中,不满足on条件的记录用空值替换。
full join:返回两张表中的所有记录,对于不满足on条件一端的记录用空值替换。
inner jon:只返回两张表中都满足on条件的记录
2, SQL语句连接查询位于两个不同的服务器不同的数据库中的两个表
select * from Product p inner join
opendatasource('SQLOLEDB','Data Source=Macaco-Online;user ID=sa;password=sa密码;').Company.dbo.Product p2
on P.PID=p2.PID
go
执行时出现错误提示:
-----------------------------------------------------------------
消息 15281,级别 16,状态 1,第 1 行 SQL Server 阻止了对组件 'Ad Hoc Distributed Queries' 的 STATEMENT'OpenRowset/OpenDatasource' 的访问,因为此组件已作为此服务器安全配置的一部分而被关闭。系统管理员可以通过使用 sp_configure 启用 'Ad Hoc Distributed Queries'。有关启用 'Ad Hoc Distributed Queries' 的详细信息,请参阅 SQL Server 联机丛书中的 "外围应用配置器"。
-----------------------------------------------------------------
嗯 这个提示似乎很明确 从上面的提示我们可以知道只要启用外围应用配置器的Ad Hoc Distributed Queries组件即可 随即把自己机器上数据库服务器的外围应用配置器打开 找到Ad Hoc Distributed Queries组件并将其启用(启用步骤:右击自己的数据库服务器,在右键菜单中选择“方面” 在弹出的的窗口中有一个名为方面的下拉列表先项点开后选择“外围应用配置器”选项,然后在下面的方面属性窗口中将AdHocremoteQueriesEnabled的状态改成true点击确定即要可)
现在就可以执行上面的应该查询语句了。
这似乎并不能满足我们的需要
例如:我们要在自己的程序中做这样的的查询那该怎么办呢?总不能一直这样开着吧 这可是对服务器有安全损耗的 嗯 我可不会就这样把自己服务器的安全级别降低哦。
好吧 我们现在需要使用SQL命令来启用和禁用这个组件,但是怎么做呢? 不要急再分析一下上面出错时的提醒我们便可以知道使用SP_Configure便可以启用禁用这个组件了 现在改变我们的SQL命令如下所示:
exec sp_configure 'show advanced options',1
reconfigure
exec sp_configure 'Ad Hoc Distributed Queries',1
reconfigure
go
select * from Product p inner join
opendatasource('SQLOLEDB','Data Source=Macaco-Online;user ID=sa;password=sa密码;').Company.dbo.Product p2
on P.PID=p2.PID
go
exec sp_configure 'Ad Hoc Distributed Queries',0
reconfigure
exec sp_configure 'show advanced options',0
reconfigure
go
嗯 这样我们就可以在需要启用这样组件的时候启用即可(注:Ad Hoc Distributed Queries是高级配置所以需要先启用Show advanced options 也就是说无论你是要启用Ad Hoc Distributed Queries还是禁用都必须保证show advanced options为启用状态)有些朋友便疑惑了你这样又是存储过程又是SQL语句的我在程序里该执行什么类型的命令啊 呵呵 其实 SqlCommand对象执行命令时就象是我们用Microsoft SQL Server Management Studio新建了一个查询窗口一样在这个查询窗口里你可以执行什么 SqlCommand对象就可以执行什么 所以你只要将上面的sql命令中的换行符替换成空格组成一串字符串然后把他赋值给SqlCommand对象的CommadnTest属性 然后执行就可以了(哦 好像我还没有使用这种方法创建数据库 不过如果你连接数据库使用的用户权限足够的化应该也没有什么问题!)
相关文章推荐
- 同时连接两个不同服务器的数据库查询
- Spark连接不同的两个服务器时的联系人列表的问题
- sql中连接两个不同的数据库(A在同一个服务器,B不在一个服务器)
- 分别在两个不同的服务器安装appserver和sqlserver,出现appser启动不了的问题
- 连接两个服务器进行查询
- sqlserver 跨服务器连接查询
- SqlServer 连接远程服务器数据库 实现跨服务器联合查询
- C#连接sqlserver分页查询的两个简单的方法
- 连接参数SqlServer跨服务器查询
- sqlserver在两个不同的服务器上操作数据
- sqlserver 在两个不同的服务器上操作数据...
- 服务器同时安装了两个版本的sql,如果分别连接不同版本的sql上的数据库
- sqlserver 在两个不同的服务器上操作数据...
- 和SQL内连接不同,SQL外连接返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行,下面就为您详细介绍SQL外连接,
- SQLServer 查询当前服务器有多少连接请求的语句
- SqlServer 不同服务器之间数据库连接、数据库登录、数据传递
- 不同服务器不同数据库两张表连接查询使用经验 数据库基础教程
- sqlserver中几种连接查询的区别
- orcale 查询两个不同的条件的结果的差值(minus)
- "SQLServer复制需要有实际的服务器名称才能连接到服务器,请指定实际的服务器名"转