sql语句增删改查|SQL语句查询服务器不同库的两张表联查

更新时间:2018-07-03    来源:php常用代码    手机版     字体:

【www.bbyears.com--php常用代码】

同台服务器不同库的两张表联查

这种方法只限于在同台服务器的数据库
一、建立两个数据库,库A(表a) 和 库B(表b) 。
二、给两个库分配同样的帐号权限。
三、在查询的时候使用下面语句:

 代码如下 select * from A.dbo.a, B.dbo.b where A.dbo.a.id=B.dbo.b.id

 
这个sql语句达到的效果就是 库A 和 库B  中,表a 和 表b 中id相等的数据。

以上方法就是一个简单的同服务器不同库的连表查询。

不同服务器不同数据库两张表连接查询

使用SQL语句连接查询位于两个不同的服务器不同的数据库中的两张表,最初将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属性 然后执行就可以了

本文来源:http://www.bbyears.com/jiaocheng/42578.html

猜你感兴趣

热门标签

更多>>

本类排行