设为首页 收藏本站
查看: 934|回复: 0

[经验分享] Oracle 大小写区分的处理 中文排序

[复制链接]
YunVN网友  发表于 2016-8-15 06:45:45 |阅读模式
Oracle 大小写区分的处理

查询数据的时候。

SQL Server 默认 不区分大小写。 如果要区分,就要额外的设置。

Oracle 默认 区分大小写。如果不要区分,就要额外的设置。



下面就是 Oracle 的明细部分了。



首先是测试表/数据

SQL> CREATE TABLE tab (

2    id  INT,

3    val VARCHAR2(10)

4  );



表已创建。



SQL> INSERT INTO tab

2    SELECT 1, 'ABC123' FROM DUAL UNION ALL

3    SELECT 2, 'abc234' FROM DUALUNION ALL

4    SELECT 3, 'Abc345' FROM DUAL UNION ALL

5    SELECT 4, 'aBC456' FROM DUALUNION ALL

6    SELECT 5, 'aBc567' FROM DUAL;



已创建5行。



=操作的例子

SQL> SELECT

2    *

3  FROM

4    tab

5  WHERE

6   val = 'abc123';



未选定行



SQL> SELECT

2    *

3  FROM

4    tab

5  WHERE

6   val = 'ABC123';



       ID VAL

---------- ----------

        1 ABC123



由上面的结果可以看出,默认情况下,Oracle 大小写敏感的。



下面通过设置环境变量,让Oracle对大小写不敏感



SQL> ALTER SESSION SET NLS_COMP=ANSI;



会话已更改。



SQL> ALTER SESSION SET NLS_SORT=binary_ci;



会话已更改。



SQL> SELECT

2    *

3  FROM

4    tab

5  WHERE

6   val = 'abc123';



       ID VAL

---------- ----------

        1 ABC123



LIKE操作的例子

SQL> SELECT

2    *

3  FROM

4    tab

5  WHERE

  6   val LIKE 'a%';



       ID VAL

---------- ----------

        2 abc234

        4 aBC456

        5 aBc567



默认是大小写敏感。



SQL> ALTER SESSION SET NLS_COMP=ANSI;



会话已更改。



SQL> ALTER SESSION SET NLS_SORT=binary_ci;



会话已更改。



会话更改以后,条件是  val = 的,可以实现大小写不敏感

但是对于 val LIKE 的查询,还是大小写敏感的。



解决办法,使用正则表达式的方式来变通的处理。



SQL> SELECT

2    *

3  FROM

4    tab

5  WHERE

6   REGEXP_LIKE (val, '^a', 'i');



       ID VAL

---------- ----------

        1 ABC123

        2 abc234

        3 Abc345

        4 aBC456

        5 aBc567



注1:REGEXP_LIKE 的第3个参数'i' 表示大小写敏感。

注2:对于环境变量NLS_COMP 与NLS_SORT的设置,会影响REGEXP_LIKE 执行的结果(假如第3个参数不填写的话)。





默认情况下:

SQL> SELECT

2    *

3  FROM

4    tab

5  WHERE

6   REGEXP_LIKE (val, '^a');



       ID VAL

---------- ----------

        2 abc234

        4 aBC456

        5 aBc567



ALTER SESSION SET … 之后



SQL> SELECT

2    *

3  FROM

4    tab

5  WHERE

6   REGEXP_LIKE (val, '^a');



       ID VAL

---------- ----------

        1 ABC123

        2 abc234

        3 Abc345

        4 aBC456

        5 aBc567







排序的例子




SQL> SELECT

2    *

3  FROM

4    Tab

5  ORDER BY

6    val;



       ID VAL

---------- ---------

        1 ABC123

        3 Abc345

        4 aBC456

        5 aBc567

        2 abc234



默认排序为大小写敏感



SQL> ALTER SESSION SET NLS_COMP=ANSI;



会话已更改。



SQL> ALTER SESSION SET NLS_SORT=binary_ci;



会话已更改。



SQL> SELECT

2    *

3  FROM

4    Tab

5  ORDER BY

6    val;



       ID VAL

---------- ----------

        1 ABC123

        2 abc234

        3 Abc345

        4 aBC456

        5 aBc567



关于中文汉字的排序




SQL> TRUNCATE TABLE Tab;



表被截断。



SQL>

SQL> INSERT INTO tab

2    SELECT 1, '一' FROM DUAL UNION ALL

3    SELECT 2, '二' FROM DUAL UNION ALL

4    SELECT 3, '三' FROM DUAL UNION ALL

5    SELECT 4, '四' FROM DUAL UNION ALL

6    SELECT 5, '五' FROM DUAL;



已创建5行。



SQL> commit;



提交完成。





-- 按照拼音来排序

SQL> SELECT

2    *

3  FROM

4    Tab

5  ORDER BY NLSSORT(val, 'NLS_SORT=SCHINESE_PINYIN_M');



       ID VAL

---------- ----------

        2 二

        3 三

        4 四

        5 五

        1 一



-- 按照笔画数来排序

SQL> SELECT

2    *

3  FROM

4    Tab

5  ORDER BY NLSSORT(val, 'NLS_SORT=SCHINESE_STROKE_M');



       ID VAL

---------- ----------

        1 一

        2 二

        3 三

        5 五

        4 四



-- 按照偏旁部首来排序



SQL> INSERT INTO tab

2    SELECT 6, '人' FROM DUAL UNION ALL

3    SELECT 7, '十' FROM DUAL UNION ALL

4    SELECT 8, '土' FROM DUAL UNION ALL

5    SELECT 9, '士' FROM DUAL;



已创建4行。



SQL> commit;



提交完成。



SQL> SELECT

2    *

3  FROM

4    Tab

5  ORDER BY NLSSORT(val, 'NLS_SORT=SCHINESE_RADICAL_M');



       ID VAL

---------- ----------

        1 一

        2 二

        3 三

        5 五

        6 人

        7 十

        4 四

        8 土

        9 士



已选择9行。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-257783-1-1.html 上篇帖子: 关于ORACLE数据库中权限和角色的探索 下篇帖子: oracle 递归查询一个树形结构的菜单
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表