标签:sku COMMENT DEFAULT barcode 大小写 mysql 字符串 NULL poc
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 '商品条形码';
标签:sku,COMMENT,DEFAULT,barcode,大小写,mysql,字符串,NULL,poc 来源: https://www.cnblogs.com/zhangzhiping35/p/15125162.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。