1. 程式人生 > 其它 >mysql字串查詢區分大小寫

mysql字串查詢區分大小寫

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 '商品條形碼';