mysql字符串查询区分大小写

本文介绍了MySQL中如何配置字符串字段以实现大小写敏感查询。通过使用BINARY关键字或修改表结构来指定VARCHAR类型为BINARY,可以确保字符串比较时严格区分大小写。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

记录前天几遇到一个问题。

mysql在根据字符串查询的时候:

select * from poc_sku where barcode = 'ZR01961050100'

 

查出的barcode值是zr01961050100。

也就是说,mysql默认为字符串'zr'和'ZR'是一样的。但在java中,如果大小写敏感,显然这是不对的。

如果想要查询的时候,严格区分字符串大小写,解决方案很简单,在查询的时候,使用关键字binary ,指定相应的列转换成二进制就可以了,比如上面的sql变成:

select * from poc_sku where binary barcode = 'ZR01961050100'。

 

 

上面只是查询的时候简单处理,但每次都要做二进制转换,似乎也不太合理。最好的方法是在建表的时候,指定相关的列大小写敏感。比如:

原先建表sql:(此时大小写不敏感)

CREATE TABLE `poc_sku` (
  `poc_sku_id` BIGINT(20) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '商品ID',
  `barcode` VARCHAR(128) NOT NULL DEFAULT '' COMMENT '商品条形码',
  `poc_vendor_code` VARCHAR(50) NOT NULL DEFAULT '' COMMENT '商家编码',
  PRIMARY KEY (`poc_sku_id`)
) ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='商品基本信息'
 

 

修改后,指定barcode列严重区分大小写

CREATE TABLE `poc_sku` (
  `poc_sku_id` BIGINT(20) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '商品ID',
  `barcode` VARCHAR(128) BINARY NOT NULL DEFAULT '' COMMENT '商品条形码',
  `poc_vendor_code` VARCHAR(50) NOT NULL DEFAULT '' COMMENT '商家编码',
  PRIMARY KEY (`poc_sku_id`)
) ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='商品基本信息'
 

 

如果表原先已经建好了,并且线上已经有好多数据之后不方便drop表重建,也可以用修改表结构的ddl做变更,如:

ALTER TABLE poc_sku MODIFY `barcode` VARCHAR(128) BINARY NOT NULL DEFAULT '' COMMENT '商品条形码';

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值