分布式查询

转载 2006年05月30日 13:19:00
应用语句如下:
--启动远程服务器的MSDTC服务
exec master..xp_cmdshell 'isql /S"192.168.253.5" /U"dl" /P"333263" /q"exec
master..xp_cmdshell ''net start msdtc'',no_output"',no_output
--启动本机的MSDTC服务
exec master..xp_cmdshell 'net start msdtc',no_output

insert into dayquantity(station_number,data_date,day_water_quantity)
(select us.station_number,date1,quantity from [192.168.253.5].manger.dbo.day_report da inner
join [192.168.253.5].manger.dbo.userdata us on da.uid=us.uid where date1<'2005-9-1' and
station_number is not null)
 
遇到过的问题:
1、问题一
服务器: 消息 8501,级别 16,状态 1,行 1
服务器 'H' 上的 MSDTC 不可用。
服务器: 消息 7391,级别 16,状态 1,行 1
该操作未能执行,因为 OLE DB 提供程序 'SQLOLEDB' 无法启动分布式事务。
OLE DB 错误跟踪[OLE/DB Provider 'SQLOLEDB' ITransactionJoin::JoinTransaction returned
0x8004d01c]。
解决办法:
--启动远程服务器的MSDTC服务
exec master..xp_cmdshell 'isql /S"192.168.253.5" /U"dl" /P"333263" /q"exec
master..xp_cmdshell ''net start msdtc'',no_output"',no_output
--启动本机的MSDTC服务
exec master..xp_cmdshell 'net start msdtc',no_output
 
2、问题二
出错信息:
[OLE/DB provider returned message: 新事务不能登记到指定的事务处理器中。 ]
OLE DB 错误跟踪[OLE/DB Provider 'SQLOLEDB' ITransactionJoin::JoinTransaction returned
0x8004d00a]。
该操作未能执行,因为 OLE DB 提供程序 'SQLOLEDB' 无法启动分布式事务。
解决办法:因为其中一台服务器不支持'SQLOLEDB' ,于是把语句换成在这台服务器上执行。
调试方法:
一.A.不用事务,关用SELECT 语句.是否可以分布式查询?
   B.LINKSERVER 在做分布式更新事务时不能对本机操作.(就是不能环回分布式事务)
   C.DBCC TRACEON (3604, 7300)--用跟踪看更详细错误信息.
 
   D.下载MS提供的DTCPing.exe 分装在两台机上,按README说明来运行它.看出错信息.
http://download.microsoft.com/download/complus/msdtc/1.7/nt45/en-us/DTCPing.exe
二.两台机的MSDTC是否都打开了.
三.MSDTC设置是否正确.
1.打开命令提示,运行"net stop msdtc",然后运行"net start msdtc"。
2.转至"组件服务管理工具"。
3.浏览至"启动管理工具"。
4.选择"组件服务"。
 a.展开"组件服务"树,然后展开"我的电脑"。
 b.右键单击"我的电脑",然后选择"属性"。
 C.在 MSDTC 选项卡中,确保选中了下列选项: 网络 DTC 访问
网络管理
网络事务
    XA 事务
 e.另外,"DTC 登录帐户"一定要设置为"NT Authority/NetworkService"。
5.单击"确定"。这样将会提示您"MS DTC 将会停止并重新启动。
  所有的依赖服务将被停止。请按'是'继续"。单击"是"继续。
6.单击"确定"关闭"我的电脑"属性窗口。
四.
MSDTC依赖于RPC,RPC使用的端口是135,测试135端口是否打开.是否有防火墙?如果有先关了防火墙.
telnet IP 135
如果是关闭的打开它.
五.
有的机由于各种原因),SQLOLEDB不能使用分布式事务,更改为"MSDASQL" 的ODBC方式联接.
使用RRAS而不是RAS.(控制面版--管理工具--远程服务管理器)
Check whether you are using Remote Access Server (RAS) to access remote servers. If so, make
sure that you have implemented Routing RAS (RRAS). Linked server does not work on RAS
because RAS allows only one way communication.
七.检查你的两台服务器是否在同一个域中.
如果不在同一个域中,是否建立可信任联接.
八.如果是WIN2000,升级到SP4
九.升级MDAC到2.6以上,最好是2.8.
十.要安装SQL的最新补丁:

分布式查询

/*分布式查询*/分布式查询(Distributed Query)能够访问存放在同一部计算机或不同计算机上的SQL Server或不同种类的数据源。众所周知,OLE DB是Microsoft规格的公用...
  • hxd001_810
  • hxd001_810
  • 2007年12月07日 17:34
  • 2575

分布式内存数据技术为查询提速

背景和需求   中国铁路客户服务中心网站(www.12306.cn)是世界规模最大的实时交易系统之一,媲美Amazon.com,节假日尤其是春节的访问高峰,网站压力巨大。据统计, 在2012年初...
  • FENGQIYUNRAN
  • FENGQIYUNRAN
  • 2015年03月06日 10:43
  • 1104

SQL SERVER 经验小结

1     在两个表关联时,写关联条件时注意,不要将有空值或为Null的字段作为连接字段 eg A表 :姓名,性别,年龄 B表:姓名,工作情况 注意:姓名有空值或为null 若select * fro...
  • qlshuang
  • qlshuang
  • 2012年02月12日 15:02
  • 1279

SQLServer分布式查询

--用openrowset连接远程SQL或插入数据 --如果只是临时访问,可以直接用openrowset --查询示例 select * from openrowset('SQLOLEDB','sq...
  • marvel_java
  • marvel_java
  • 2016年12月04日 12:59
  • 727

解决MSSQL不支持分布式(linked server)调用用户自定义函数的解决办法

MSSQL并不支持用户自定义函数调用linked server查询,它无法识别链接服务器部分 但我们可以采用其他方式,替换无法被解析的linked server部分内容 1、采用Openquer...
  • starseeker7
  • starseeker7
  • 2013年01月30日 14:34
  • 779

分布式大数据sql查询引擎Presto初识

1、背景: Hive使用MapReduce作为底层计算框架,是专为批处理设计的。但随着数据越来越多,使用Hive进行一个简单的数据查询可能要花费几分到几小时,显然不能满足交互式查询的需求。Presto...
  • fjssharpsword
  • fjssharpsword
  • 2017年07月05日 16:33
  • 1816

在分布式系统中进行日志查询与管理的新手段介绍

随着技术的发展,越来越多的系统从单机转向到分布式,同时对应的日志查看方式除了直接查看文件外,也发展出了各种集中日志管理方式。其中常见日志查看方式如下:...
  • Gamay
  • Gamay
  • 2017年06月13日 11:38
  • 625

分布式查询

 前几天做一个分布式查询遇到了一些问题(问题详细描叙见:http://www.cnblogs.com/lizhiwen/archive/2007/08/24/868141.html),经过反复查找,总...
  • vipxiaotian
  • vipxiaotian
  • 2007年10月24日 14:20
  • 1117

海量数据处理---分布式处理之MapReduce

方法介绍 MapReduce是一种计算模型,简单的说就是将大批量的工作(数据)分解(MAP)执行,然后再将结果合并成最终结果(REDUCE)。这样做的好处是可以在任务被分解后,可以通过大量机器进...
  • qisefengzheng
  • qisefengzheng
  • 2015年05月26日 15:48
  • 419

实战Spark分布式SQL引擎

Spark SQL除了使用spark-sql命令进入交互式执行环境之外,还能够使用JDBC/ODBC或命令行接口进行分布式查询,在这个模式下,终端用户或应用可以直接和Spark SQL进行交互式SQL...
  • opensure
  • opensure
  • 2015年06月24日 20:57
  • 3177
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:分布式查询
举报原因:
原因补充:

(最多只允许输入30个字)