免费注册 查看新帖 |

Chinaunix

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

db2 中有没有数字性字符转数字的函数. [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2004-10-14 11:21 |只看该作者 |倒序浏览
我在用select * from tab order by zh 要求按帐号进行排序,可是zh是数字性字符,不能按要求进行排序输出. 有没有将这种数字性字符转换成数字的函数. 谢

论坛徽章:
0
2 [报告]
发表于 2004-10-14 12:30 |只看该作者

db2 中有没有数字性字符转数字的函数.

order by dec(zh)
即可

论坛徽章:
0
3 [报告]
发表于 2004-10-14 12:43 |只看该作者

db2 中有没有数字性字符转数字的函数.

不需要类型转换函数,就可以排序吧.
select * from tab order by zh
没问题的。

论坛徽章:
0
4 [报告]
发表于 2004-10-14 12:49 |只看该作者

db2 中有没有数字性字符转数字的函数.

的确是这样,字符串是按照每一个字符的ASCII码进行排序的,直接排序即可,不用转换。

论坛徽章:
0
5 [报告]
发表于 2004-10-14 14:21 |只看该作者

db2 中有没有数字性字符转数字的函数.

原帖由 "zly0411" 发表:
不需要类型转换函数,就可以排序吧.
select * from tab order by zh
没问题的。


[quote]原帖由 "足球小子"]的确是这样,字符串是按照每一个字符的ASCII码进行排序的,直接排序即可,不用转换.[/quote 发表:


不对吧!

模拟例子:

表结构:

  1. C:\>;db2 describe table company

  2. 列                             类型      类型
  3. 名称                           模式      名称               长度     小数位  NULL
  4. ------------------------------ --------- ------------------ -------- ----- ------
  5. COMNO                          SYSIBM    VARCHAR                   5     0 是

  6. COMPANY                        SYSIBM    CHARACTER                20     0 是

  7. MONEY                          SYSIBM    DECIMAL                  10     2 是

复制代码


其中comno为varchar类型, 模拟楼主的数字型字符

表记录:

  1. C:\>;db2 select * from company

  2. COMNO COMPANY              MONEY
  3. ----- -------------------- ------------
  4. 2     公司2                      100.00
  5. 1     公司1                      100.00
  6. 4     公司4                      100.00
  7. 3     公司3                      100.00
  8. 7     公司7                      100.00
  9. 11    公司7                      100.00
  10. 10    公司7                      100.00
复制代码


排序结果: order by comno,不做转换

  1. C:\>;db2 select * from company order by comno

  2. COMNO COMPANY              MONEY
  3. ----- -------------------- ------------
  4. 1     公司1                      100.00
  5. 10    公司7                      100.00
  6. 11    公司7                      100.00
  7. 2     公司2                      100.00
  8. 3     公司3                      100.00
  9. 4     公司4                      100.00
  10. 7     公司7                      100.00
复制代码


不符合楼主的要求吧!

转换后排序结果:

  1. C:\>;db2 select * from company order by dec(comno)

  2. COMNO COMPANY              MONEY
  3. ----- -------------------- ------------
  4. 1     公司1                      100.00
  5. 2     公司2                      100.00
  6. 3     公司3                      100.00
  7. 4     公司4                      100.00
  8. 7     公司7                      100.00
  9. 10    公司7                      100.00
  10. 11    公司7                      100.00
复制代码


正确排序

论坛徽章:
0
6 [报告]
发表于 2004-10-14 15:09 |只看该作者

db2 中有没有数字性字符转数字的函数.

楼上的是正解.    例子同我的问题一样.      感谢各位.    感谢jourmen

论坛徽章:
0
7 [报告]
发表于 2004-10-14 20:46 |只看该作者

db2 中有没有数字性字符转数字的函数.

原来编号位数可以变啊,我以为是统一的位数呢,比如说“00001”、“00002”、.......、“99999”

位数不统一当然就必须转换为数字了,误会误会。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP