?
引
今天在开发中,遇到一个很有意思的问题。有个工作计划列表,填写工作计划列表有几个输入框。1.工作计划时间 2.工作计划标题 3.工作计划内容。其中,需要判断标题是否已经存在。
方法一是我们最常见的做法,但这样往往有问题。
?
发现问题了吗?对,没错 Mysql它是大小写不敏感的。如果页面填写标题时,全部输入大写的话,按照方法一最终提交是不成功的。因为根据传入标题是能匹配到数据的。我们继续往下看,首先我们看设计表中的字段
?
utf8_bin将字符串中的每一个字符用二进制数据存储,区分大小写。
utf8_genera_ci不区分大小写,ci是case insensitive的缩写,即一般大小写不敏感。
insensitive ; 中文解释: adj. 感觉迟钝的,对…没有感觉的
?
utf8_general_cs区分大小写,cs是case sensitive的缩写,即大小写敏感。
case sensitive 中文解释:敏感事件;大小写敏感;注重大小写;全字拼写须符合
?
用utf8_genera_ci没有区分大小写,导致这个字段的内容区分大小写时出问题:
作为密码时就会出现不合理的方面;
而验证码则一般不区分大小写,所以用这个就合理
utf8_general_cs这个选项一般不用,所以使用utf8_bin区分大小写
如果,多个服务共用一张表,一些服务需要做大小写敏感,一些服务不需要做大小写敏感。这又怎么办呢?
所以,可以采用第二种方法。
// 先查询所有工作计划
List<Work> sel = mapper.sel(work); ? ?
// 根据工作计划名称过滤
boolean present = sel.stream().filter(work -> work.getName().equals("daf")).findAny().isPresent();
?
1、使用equals( )方法比较两个字符串是否相等。它具有如下的一般形式:
?
boolean equals(Object str)
?
这里str是一个用来与调用字符串(String)对象做比较的字符串(String)对象。如果两个字符串具有相同的字符和长度,它返回true,否则返回false。这种比较是区分大小写的。
?
2、为了执行忽略大小写的比较,可以调用equalsIgnoreCase( )方法。当比较两个字符串时,它会认为A-Z和a-z是一样的。其一般形式如下:
?
boolean equalsIgnoreCase(String str)
?
这里,str是一个用来与调用字符串(String)对象做比较的字符串(String)对象。如果两个字符串具有相同的字符和长度,它也返回true,否则返回false
加入我们群 如果有需要,欢迎可以加入我们的技术交流vx群!
?
?
|