免费注册 查看新帖 |

Chinaunix

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

SQL怎样模拟RPG中的SETLL定位啊? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-12-07 17:50 |只看该作者 |倒序浏览
如果只有一个KEY FIELD那还可以,如果有多个KEY FIELD真的想不出有什么好主意。做过这类东西的有什么经验拿出来共享一下巴!

论坛徽章:
0
2 [报告]
发表于 2009-12-07 18:23 |只看该作者
使用 cursor: order by fld1, fld2, ...
fetch
可行吗?

我发现SQLRPGLE使用比较复杂的 sum group by 要改用 LF+RPGLE来实现比较麻烦
SQLRPGLE可能占用CPU比较厉害,是因为没有可利用的LF?

论坛徽章:
0
3 [报告]
发表于 2009-12-07 19:54 |只看该作者

回复 #1 法郎士 的帖子

这个问题有点像用8位机的汇编语言写一个比较字符串大小的程序。
8位机每次只可以比较一个字节(相当于这里我们一次只可以比较一个键值)。setll的条件类似于文件的键值和 setll 的键值:

my_pos_key  klist
                      kfld                                     p1
                      kfld                                     p2
                      kfld                                     p3
                      ...
                      kfld                                     pn

my_pos_key  setll   my_file



K1K2K3K4K5...KN  >= P1P2P3P4P5...PN

我们从左到右进行比较:

如果K1>p1, 肯定满足条件。
如果K1=p1, 再比较下一个键。
如果K1<p1, 立马出局,比都不用比。
.....
如果K2>p2, 肯定满足条件。
如果K2=p2, 再比较下一个键。
如果K2<p2, 立马出局,比都不用比。
...
如果Kn>=pn, 肯定满足条件。
如果Kn<pn, 立马出局,比都不用比。

用SQL CURSOR陈述就像下面一样子:

DECLARE C1 CURSOR FOR SELECT * FROM MY_FILE
WHERE

K1>:p1
OR
K1=:p1 AND K2>:p2
OR
K1=:p1 AND K2=:p2 AND K3>:p3
OR
...
OR
K1=:p1 AND K2=:p2 AND K3=:p3 AND ... AND Kn-2>:pn-2
OR
K1=:p1 AND K2=:p2 AND K3=:p3 AND ... AND Kn-2=:pn-2 AND Kn-1>:pn-1
OR
K1=:p1 AND K2=:p2 AND K3=:p3 AND ... AND Kn-2=:pn-2 AND Kn-1=:pn-1 AND Kn>=pn

ORDER BY
K1, K2, K3, ... Kn


好像太复杂。有没有更好的方法呢?先抛砖引玉一下。请网友们多提建议。

这种方法只可以前进,不能倒退(如用于subfile 的 page-up).

[ 本帖最后由 franliu 于 2009-12-8 10:04 编辑 ]

论坛徽章:
0
4 [报告]
发表于 2009-12-07 20:46 |只看该作者
使用游标定义在WHERE里写条件
然后用FETCH读取

论坛徽章:
0
5 [报告]
发表于 2009-12-07 20:52 |只看该作者
游标OPEN的时候就相当于定位了

论坛徽章:
0
6 [报告]
发表于 2009-12-07 21:11 |只看该作者

回复 #4 giggsone 的帖子

这个我知道啊。问题是where 的条件有没有可能简化一些。

论坛徽章:
0
7 [报告]
发表于 2009-12-07 21:50 |只看该作者

回复 #6 法郎士 的帖子

简化到什么程度啊
WHERE K1 = W#K1  AND
             K2 = W#K2
ORDER BY K1  
               ,K2
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP