免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4323 | 回复: 2
打印 上一主题 下一主题

已经解决,多谢! 求助,远程执行存储过程。 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-04-25 10:07 |只看该作者 |倒序浏览
我有两个服务器,分别为server1,server2,两机已经建立了互相信任。
我在server1上用dbaccess执行select * from dbname@server2:tablename;是成功返回值的。
但是执行execute procedure dbname@server2:procedurename();总是提示-674错误。
但是我在server2上是可以执行的。
为何?

[ 本帖最后由 xxyyy 于 2007-4-25 17:57 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2007-04-25 12:08 |只看该作者
我试了下是可以的。
双方都可以执行。
存储过程dbname@server2:procedurename 是否真的存在?

论坛徽章:
0
3 [报告]
发表于 2007-04-25 17:49 |只看该作者

已经解决,多谢。

原帖由 wenlq 于 2007-4-25 12:08 发表
我试了下是可以的。
双方都可以执行。
存储过程dbname@server2:procedurename 是否真的存在?


原来,存储过程本地执行,对参数列表的数据类型自动转换,而远程执行不会自动转换,我必须严格匹配传入参数的数据类型,然后执行就行了。
因为我这个存储过程有些参数为date型,有些参数为char型。
原来过程定义为procedurename(a char(5),b char(5),c date);
调用execute dbname@server2:procedurname( "aa","bb","04/25/2007");错误-674
调用execute dbname@server2:procedurname( "aa","bb",date("04/25/2007"));错误-674


过程定义必须这样procedurename(a varchar(5),b varchar(5),c date);
调用execute dbname@server2:procedurname( "aa","bb","04/25/2007");错误-674
调用时必须execute dbname@server2:procedurname( "aa","bb",date("04/25/2007"));成功。

[ 本帖最后由 xxyyy 于 2007-4-25 17:58 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP