不同服务器不同数据库两张表连接查询使用经验

使用SQL语句连接查询位于两个不同的服务器不同的数据库中的两张表,最初将SQL语句写成以下形式 

  1. select * from Product p inner join 
  2. opendatasource('SQLOLEDB','Data Source=Macaco-Online;user ID=sa;password=sa密码;').Company.dbo.Product p2  
  3. on P.PID=p2.PID  
  4. 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命令如下所示:

  1. exec sp_configure 'show advanced options',1  
  2. reconfigure  
  3. exec sp_configure 'Ad Hoc Distributed Queries',1  
  4. reconfigure  
  5. go  
  6.  
  7. select * from Product p inner join 
  8. opendatasource('SQLOLEDB','Data Source=Macaco-Online;user ID=sa;password=sa密码;').Company.dbo.Product p2  
  9. on P.PID=p2.PID  
  10. go  
  11.  
  12. exec sp_configure 'Ad Hoc Distributed Queries',0  
  13. reconfigure  
  14. exec sp_configure 'show advanced options',0  
  15. reconfigure  
  16.    
  17.  
  18. 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.cnblogs.com/macacoonline/archive/2011/02/25/1964674.html

补充阅读:

来源:博客园

作者:邹泽栋

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条件的记录

原文链接:http://www.cnblogs.com/zouzedong/archive/2011/02/27/1966534.html

【编辑推荐】

  1. 一些常用的SQL语句
  2. 查询表结构的SQL语句
  3. 使用SQL语句查询时间段
  4. 巧用SQL语句删除重复记录
  5. 判断字段是否存在的SQL语句写法

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/282653.html<

(0)
运维的头像运维
上一篇2025-05-13 13:49
下一篇 2025-05-13 13:50

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注