不同版本操作系统和数据库的之间链接,和操作

缘由: 知识库个人计划积分数据源为157数据库,但基于BI等系统,34上复制了一份单独的知识库个人计划积分,所以每次157发生变化,要人工的改变34数据库,这样操作起来很麻烦。

所以在157写了个触发器,同步更新34数据库的个人计划积分。但遇到了种种问题。

该问题自动化的整体思路:在157计划计分表中建立触发器,同步更新34数据库(看是很简单,实施有点麻烦)

问题一:64位Windows2003,SqlServer2005,链接32位Windows2003,SqlServer2000,无法链接
错误提示:

链接服务器"nebula"的 OLE DB 访问接口 "SQLNCLI" 返回了消息 "未指定的错误"。
链接服务器"nebula"的 OLE DB 访问接口 "SQLNCLI" 返回了消息 "在该服务器上找不到完成该操作所需的存储过程。 请与系统管理员联系。"。
消息 7311,级别 16,状态 2,第 1 行
无法获取链接服务器 "nebula" 的 OLE DB 访问接口 "SQLNCLI" 的架构行集 "DBSCHEMA_TABLES_INFO"。该访问接口支持该接口,但使用该接口时返回了失败代码。


解决方案:
1.确保被链接的sqlserver2000安装了sp4,否则请先安装
2.安装完成后,运行cmd,执行如下命令osql -U sa -P ovenjackchain -S 192.168.0.34 -i C:\instcat.sql
   注意用户名和密码,最后的C:\instcat.sql,如果你安装了sp4,那么这个文件肯定存在,自己搜索出来。
3.回车,哗哗哗的一幕,最后提示成功!
4.执行成功后,即可建立两台数据库的链接了(如何建立,请搜索知识库)


问题二:创建触发器,创建失败
错误提示:
包含的前缀超出了最大限值。最多只能有 2 个
触发器如下:
01create trigger T_Changescore
02on  Y_TaskScoreplanning for update,delete,insert as
03begin
04drop table nebula.Nebula.dbo.taskplaning;
05insert into nebula.Nebula.dbo.taskplaning
06select case [任务型态] when '投-知识库学习' then '学习' when '投-知识库发展' then '发展' end tasktype,case 节点负责人 when '姚亮' then '姚亮' else substring(节点负责人,3,100) end taskman,年度 year,isnull(m01,0) m01,isnull(m02,0) m02,isnull(m03,0) m03,isnull(m04,0) m04,isnull(m05,0) m05,isnull(m06,0) m06,isnull(m07,0) m07,isnull(m08,0) m08,isnull(m09,0) m09,isnull(m10,0) m10,isnull(m11,0) m11,isnull(m12,0) m12,合计 total
07from Y_TaskScoreplanning
08where ([任务型态]='投-知识库学习' or [任务型态]='投-知识库发展' ) and 年度='2011'
09and substring(节点负责人,3,100) not in ('xxxx')
10end

解决方案: 将触发器执行的代码改成存储过程执行,存储过程可以成功创建,select * into,和drop是不可以在链接中使用的
01create trigger T_Changescore
02on  Y_TaskScoreplanning for update,delete,insert as
03begin
04exec P_UpdateNebulaScore
05end
06
07create proc P_UpdateNebulaScore as
08begin
09
10delete nebula.Nebula.dbo.taskplaning;--注意
11insert into nebula.Nebula.dbo.taskplaning--注意
12select case [任务型态] when '投-知识库学习' then '学习' when '投-知识库发展' then '发展' end tasktype,case 节点负责人 when '姚亮' then '姚亮' else substring(节点负责人,3,100) end taskman,年度 year,isnull(m01,0) m01,isnull(m02,0) m02,isnull(m03,0) m03,isnull(m04,0) m04,isnull(m05,0) m05,isnull(m06,0) m06,isnull(m07,0) m07,isnull(m08,0) m08,isnull(m09,0) m09,isnull(m10,0) m10,isnull(m11,0) m11,isnull(m12,0) m12,合计 total
13from Y_TaskScoreplanning
14where ([任务型态]='投-知识库学习' or [任务型态]='投-知识库发展' ) and 年度='2011'
15and substring(节点负责人,3,100) not in ('陆趣趣','姜敏','孙亚峰','魏文','梁晓东')
16
17end

问题三:更新157个人积分计划,测试,但杯具再次上演
错误提示:
该伙伴事务管理器已经禁止了它对远程/网络事务的支持
解决方案:在两台服务器上同时执行如下操作

2011032216004326.jpg


执行完成后,再次测试,OK


一个小小的问题,背后隐藏着三个大问题,特此一记!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值