mysql排序区分大小写吗_MySQL操作数据时区分大小写

一般情况下使用SQL语句执行

update login_ticket set status=1 where ticket=‘ABC‘

会将ticket=’abc‘的数据也改掉,那么需要在列名ticket的后面加上collate utf8_bin

update login_ticket set status=1 where ticket COLLATE utf8_bin=‘ABC‘

这里的collate后面的是指该列的字符集排序方式,具体的字符集可以在SQLyog上方:数据库->更改数据库看到

20210127140646810718.png

这里可以看到可以选用的字符集排序方式,这里的ci是指case insensitive(大小写不敏感),而想要大小写敏感则要找case sensitive(cs),可见这里没有,所以只能用最上面的utf8_bin,经测试该字符集排序方式是大小写敏感的。

而网上常见的说加collate Chinese_PRC_CS_AS的都是SQL Server的,与MySQL无关。

参考:http://www.voidcn.com/article/p-rxghfnkv-btx.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值