社区
Oracle
帖子详情
请教字符数据中文数字混合时排序问题;
pastime_Wang
2005-10-13 08:51:07
请教各位:
一个field : type varchar2(20);
contents:
漏钢1
漏钢2
漏钢3
漏钢12
排序后,漏钢12 会排到漏钢2的前面,(字符排序逐位比较),如何才能
按照正常的如上的排序方式?
谢谢!!
...全文
207
13
打赏
收藏
请教字符数据中文数字混合时排序问题;
请教各位: 一个field : type varchar2(20); contents: 漏钢1 漏钢2 漏钢3 漏钢12 排序后,漏钢12 会排到漏钢2的前面,(字符排序逐位比较),如何才能 按照正常的如上的排序方式? 谢谢!!
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
13 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
zzwind5
2005-10-13
打赏
举报
回复
又学习了
还有不能对一个字段重复排序
sasacat
2005-10-13
打赏
举报
回复
我的意思就是说,你的方法只能在有限的数据库上用,不能象偶的一样放之四海而皆准
sasacat
2005-10-13
打赏
举报
回复
可是里面如果有字母呢?那就又不对了。所以还是我的办法最好....哈哈哈
zzwind5
2005-10-13
打赏
举报
回复
to傻傻猫
SQL> select lengthb('就是汉字的个数333') from dual;
LENGTHB('就是汉字的个数333')
----------------------------
17
SQL> select length('就是汉字的个数333') from dual;
LENGTH('就是汉字的个数333')
---------------------------
10
要看用什么字符集的 你的是一个汉字占3个字节,我的是占两个
sasacat
2005-10-13
打赏
举报
回复
要这样倒是可以
select to_number(substr('就是汉字的个数333', (lengthb('就是汉字的个数333')-length('就是汉字的个数333'))/2+1)) from dual
zzwind5
2005-10-13
打赏
举报
回复
上面写错了
select field from
(
select t.*, rank() over(order by substr(field, 1, lengthb(field)-length(field))) b
from table_name t)
order by b, to_number(substr(field, lengthb(field)-length(field)+1));
sasacat
2005-10-13
打赏
举报
回复
zzwind5()你说得不对吧
select lengthb('就是汉字的个数333') from dual
LENGTHB('就是汉字的个数333')
----------------------------
24
1 row selected
select length('就是汉字的个数333') from dual
LENGTH('就是汉字的个数333')
---------------------------
10
1 row selected
sasacat
2005-10-13
打赏
举报
回复
order by translate(field,'1234567890',' $'),TO_NUMBER(replace(field,translate(field,'1234567890',' $')))
bobfang
2005-10-13
打赏
举报
回复
如果要排序的字段都是只有末尾有若干位数字,那么可以自己写个函数,输入是这个字符串,返回值是将末尾的数字都变为等长的数字串(长度就取最大可能的数字串的长度为,不足补0)。例如最长的数字串长度不会超过5位,那么输入"漏钢1",返回"漏钢00001",输入"漏钢12","漏钢00012"。这样,order by这个函数就可以了。
zzwind5
2005-10-13
打赏
举报
回复
汉字个数不定时
lengthb(field)-length(field) 就是汉字的个数
order by field, to_number(substr(field, lengthb(field)-length(field)+1))
zzwind5
2005-10-13
打赏
举报
回复
order by field, to_number(substr(field, 3))
匆匆岁月
2005-10-13
打赏
举报
回复
这里面的汉字个数如果有可能是三个,四个或其他个数呢?
hevin
2005-10-13
打赏
举报
回复
order by to_number(substr(fieldName,5,length(fieldName) - 4) )
EXCEL函数公式集
排序
字母与数字的
混合
内容 随机
排序
排序
的
问题
怎样才能让数列自动加数 一个
排序
问题
数字的自动
排序
,插入后不变? 根据规律的重复的姓名列产生自动序号 排名的函数 自动排名公式 百分比排名的公式写法为: 平均分及...
Excel公式大全操作应用实例(史上最全)
排序
字母与数字的
混合
内容 随机
排序
排序
的
问题
怎样才能让数列自动加数 一个
排序
问题
数字的自动
排序
,插入后不变? 根据规律的重复的姓名列产生自动序号 排名的函数 自动排名公式 百分比排名的公式写法为: 平均分及...
尹成Python27天入门到项目实战
python
字符
串与绘图复习变量None变量参与运算没有赋值的情况不会改变绘制立方体绘制五角星
时
间计算强化实现贷款计算连续输入多个
字符
串加法与绘图实现显示线段长度
数据
函数使用快速查阅函数帮助
字符
串三种风格
字符
与...
vb/vb.net开发精粹(23)
请教
字符
串
数据
提取思路
请教
字符
串
数据
提取思路 自定义控件内模块怎么调用子控件? VB模块化“识别
数据
库路径” 为什么我的程序里kill t总是删除不了呢? VB执行SQL语句耗
时
太久导致程序假死怎么办?
请教
...
excel筛选
排序
从小到大_(Excel)常用函数公式及操作技巧之三:排名及
排序
筛选(一)...
(Excel)常用函数公式及操作技巧之三:排名及
排序
筛选(一)——通过知识共享树立个人品牌。一个具有11项汇总方式的函数SUBTOTAL=SUBTOTAL(9,$B$2:B2)在
数据
筛选求和上有意想不到的功能,11项功能为:1、求平均数,2、...
Oracle
17,078
社区成员
55,234
社区内容
发帖
与我相关
我的任务
Oracle
Oracle开发相关技术讨论
复制链接
扫一扫
分享
社区描述
Oracle开发相关技术讨论
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章