能不能告诉我,SQLServer为什么这么差?

mahongxi 2005-03-15 04:23:19
最近在忙着搞平台的数据库移植(Oracle->SQlserver),搞得一头包.
要求在不影响客户端代码的情况下,实现移植.
Oracle的包已经用AdventNet SwisSQL +我自己写的一些辅助工具转出个样子来了.
昨天遇到一个Procedure 中输出游标,在客户端访问的问题.邹健等高手告知,不能在客户端访问此输出游标.建议直接把select写在过程内部.问题是我原来的ORACLE一个过程返回N个游标啊.今天想到了把游标记录集打到临时表的办法.
现在,又遇到了问题
函数中居然不能用delete 语句?
过程居然不能返回字符串?

这不是搞笑吗?我原的业务模块有很多是FUNCTION里进行复杂操作,返回一个字符串的,现在怎么搞?

如果一定要改动过程/函数接口才能实现,那工作量可就大了去了,客户端那边本来打算不改业务代码,用2种不同的数据库访问组件访问oracle sqlserver.
接口一改动让以后的代码极难维护.

可能是小弟才疏学浅吧.心情实在是差,发几句牢骚.
SQLSERVER的确好久没碰过了,也许有什么新功能还没发现.但用了ORACLE之后,再用回它,就感到束手束脚的.
...全文
495 32 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
32 条回复
切换为时间正序
请发表友善的回复…
发表回复
qxdatabase 2005-03-18
  • 打赏
  • 举报
回复
SQL性能,功能等等,都还不错.基本上在认何地方都要使这种语言,所以说SQL还是好的哟.
我不懂ORACLE,但一直都在用SQL.总体来说SQL不错.谢谢,朋友顶一下.
郭大侠_ 2005-03-17
  • 打赏
  • 举报
回复
sql优点还是很多的
要善于发现!
mahongxi 2005-03-17
  • 打赏
  • 举报
回复
to Yang_(扬帆破浪):
嗯.谢谢提醒,SQLSERVER还有很多不懂的地方,以后还要向你请教.
我们系统前期移植的程序大多用一个输出游标,所以可以得到优化.
另外,不用临时表,用普通表也可以试试.
ADODB改了一大通,今天终于搞定了所有难点,明天调试程序!
Shires 2005-03-17
  • 打赏
  • 举报
回复
oh
huohw 2005-03-17
  • 打赏
  • 举报
回复
厉害,学习ing!
dazhu2 2005-03-17
  • 打赏
  • 举报
回复
不懂Oracle
Yang_ 2005-03-17
  • 打赏
  • 举报
回复
mahongxi(烤鸡翅膀)(色摸):
c.有返回游标的,对应的output参数类型改为varchar代表数据集所在的临时表表名
在内部,原有游标 select * into 临时表

这个方法不是很可靠,
1、如果用局部临时表(#开头),有时(经常)会出现临时表已经被删除的情况,如果用全局临时表(##开头),那必须在客户端显式删除临时表。
2、要求临时表空间足够大
3、速度需要测试
niou4401 2005-03-17
  • 打赏
  • 举报
回复
不懂Oracle
zipo 2005-03-17
  • 打赏
  • 举报
回复
没搞过,学习……
rcrain 2005-03-16
  • 打赏
  • 举报
回复
哦,看了各位留言,没懂,好深奥哦。听的我一头雾水。还要多多听课,多多学习。
mahongxi 2005-03-16
  • 打赏
  • 举报
回复
各位兄弟,问题解决了.
a.不用函数,全部用存储过程
b.有返回值的,把它改成第一个OUTPUT参数
c.有返回游标的,对应的output参数类型改为varchar代表数据集所在的临时表表名
在内部,原有游标 select * into 临时表
d.可选的,一个游标输出参数可以直接select * from ... ,对应的输出为NULL
e.客户端原有DOA,进行复杂包装,以保证原有业务代码不动

hongmingz 2005-03-15
  • 打赏
  • 举报
回复
不知道SQL SERVER 2005出来会是什么样子?
dazhu2 2005-03-15
  • 打赏
  • 举报
回复
听课,
fengpiaoyunying 2005-03-15
  • 打赏
  • 举报
回复
为什么不自己试着改动SQL的后台编制呢,

制作自己需要的SQL SERVER
天地客人 2005-03-15
  • 打赏
  • 举报
回复
学了不少!谢谢各位
lin_now 2005-03-15
  • 打赏
  • 举报
回复
也来听

Yang_ 2005-03-15
  • 打赏
  • 举报
回复
mahongxi(烤鸡翅膀)(色摸):
客气,老实说我忘了

希望你能摸索出好的方法,尽量减少改动量,到时拿出来共享一下
poonzsp 2005-03-15
  • 打赏
  • 举报
回复
听课
jinjazz 2005-03-15
  • 打赏
  • 举报
回复
mark留名
mahongxi 2005-03-15
  • 打赏
  • 举报
回复
a."函数是绝对可以返回字符串的" 但函数中不能用delete 语句,很多已有业务需要在
函数中清空临时表。
b.procedure 中用OUTPUT是可以地,但就改变了"不动客户端代码"的规则.
加载更多回复(12)

34,838

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧