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

[经验分享] Oracle 实现查询不区分大小写(设置数据库)

[复制链接]

尚未签到

发表于 2017-12-11 07:24:48 | 显示全部楼层 |阅读模式
  转http://blog.csdn.net/shl7765856/article/details/7622756
  查询数据的时候。
  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.iyunv.com/thread-422842-1-1.html 上篇帖子: 请教怎么查询ORACLE的历史操作记录! 下篇帖子: Oracle expdp impdp中 exclude/include 的使用
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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