永发信息网

Mysql怎样在SQL中实现区分大小写的查询

答案:1  悬赏:80  手机版
解决时间 2021-02-11 14:18
  • 提问者网友:我们很暧昧
  • 2021-02-11 11:21
Mysql怎样在SQL中实现区分大小写的查询
最佳答案
  • 五星知识达人网友:猎心人
  • 2021-02-11 11:49
1.问题描述
mysql版本:mariadb 10.1.16,采用utf8-ci,不区分大小写的排序规则。
开发人员反应业务要求要区分大小写,就是说当输入小写条件时,只能返回小写条件对应的数据,不能返回大写。

dba@192.168.19.215:3306mdls01:58:57>SELECt
-> cabinet_no
-> FROM
-> go_task_ycon_refrence gtyr
-> WHERe
-> 1 = 1
-> AND cabinet_no = 'abcd4499503'
-> ORDER BY
-> 1 ASC;
+-------------+
| cabinet_no |
+-------------+
| ABCD4499503 |
+-------------+
1 row in set (0.00 sec)
2.问题解决
在条件字段后面加COLLATE utf8_bin ,或在表级或字段级指定COLLATE utf8_bin
dba@192.168.19.215:3306mdls02:08:08>SELECt
-> cabinet_no
-> FROM
-> gtyr
-> WHERe
-> 1 = 1
-> AND cabinet_no COLLATE utf8_bin = 'ABCDU4499503'
-> ORDER BY
-> 1 ASC;
+-------------+
| cabinet_no |
+-------------+
| ABCD4499503 |
+-------------+
1 row in set (0.00 sec)
dba@192.168.19.215:3306mdls02:08:43>SELECt
-> cabinet_no
-> FROM
-> gtyr
-> WHERe
-> 1 = 1
-> AND cabinet_no COLLATE utf8_bin = 'abcd4499503'
-> ORDER BY
-> 1 ASC;
Empty set (0.00 sec)
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯