zoukankan      html  css  js  c++  java
  • 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 '商品条形码';

  • 相关阅读:
    数据库结构中的"树"
    Jquery学习
    cms系统也不复杂
    让你的博客园变灰
    IList对象排序方法
    计算机简介(二)
    在同一台电脑上使用U盘时快时慢的解决方法
    计算机简介
    合并排序
    javascript小结
  • 原文地址:https://www.cnblogs.com/zhangzhiping35/p/15125162.html
Copyright © 2011-2022 走看看