JAVA中字符串比较equals()和equalsIgnoreCase()的区别

本文探讨了在开发中如何避免因大小写不敏感导致的工作计划标题重复问题,介绍了使用utf8_bin区分大小写的方法,以及在实际场景中采用stream API进行过滤的解决方案。讨论了数据库设计中的字符编码选择和适应不同服务需求的策略。
摘要由CSDN通过智能技术生成

 

今天在开发中,遇到一个很有意思的问题。有个工作计划列表,填写工作计划列表有几个输入框。1.工作计划时间 2.工作计划标题 3.工作计划内容。其中,需要判断标题是否已经存在。

  • 方法一 在创建工作计划时,通过标题名称查询数据库,是否存在工作计划。如查询有数据则说明标题已存在

  • 方法二 先查询到所有数据,根据标题进行过滤,判断是否为true,存在则说明标题已存在

方法一是我们最常见的做法,但这样往往有问题。

 

发现问题了吗?对,没错 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群!


 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值