当前位置: 首页 > article >正文

【java】 java开发中 常遇到的各种难点 思路方案

文章目录

  • 逻辑删除如何建立唯一索引
  • 唯一索引失效问题
  • 加密字段模糊查询问题
  • maven依赖冲突问题(jar包版本冲突问题)
  • sql in条件查询时 将结果按照传入顺序排序
  • 数据库主从复制 主从不同步问题
  • 数据库读写分离 读写不一致
  • java服务如何作为websocket客户端

作为一个开发人员 总会遇到各种难题 本文列举博主 遇见/想到 的例子 ,也希望同学们可以在评论区举例交流 共同进步~

逻辑删除如何建立唯一索引

场景描述:

比如我们有project项目表
字段project_name 是唯一的,
且有逻辑删除字段is_delete 0表示未删除 1表示已删除

很显然 不能直接将project_name设置为唯一索引,
例如A用户建立的project_name为 java工程,又把这个工程(逻辑)删除了, 这时B用户是允许建立 java工程的。

那将is_delete project_name 共同设置为唯一索引是否可行呢? 答案也是否定的,在B用户删除时,就会出现问题了。

解决方案:
is_delete 不用0和1表示,可改为数字递增,或者时间戳(尽量小 例如纳秒级别), 这时将is_delete project_name 共同设置为唯一索引 可以解决该问题。

唯一索引失效问题

场景描述:
人员姓名和电话 组成唯一索引 。
在这里插入图片描述
在这里插入图片描述
出现问题:
有两个小孩 名字都叫小朋友 且他们都没有手机号 此时数据重复 唯一索引失效。 我们换个场景,在高并发的电商活动中,用户姓名和vip标识码 组成唯一索引,此时有两位用户 都不是vip用户,vip标识码都为空,那可能出现的问题就比较严峻了

在这里插入图片描述

解决方案: 唯一索引的字段设置为非空,因为空是允许重复的
( 不管单独将某一个字段设置为唯一索引 还是多个字段组合成唯一索引 都一样的)

加密字段模糊查询问题

场景描述: 用户敏感信息,例如手机号 身份证 户籍所在地 入库时,我们通常会加密, 这时需要模糊查询

解决方案:

  1. 数据量少时,例如只是一个公司内部系统的人员表,可以全表查询 并解密,在java代码中过滤 (如果遇到要分页,那得好好考虑怎么处理分页问题了)

  2. 与业务/产品沟通,看搜索的字数是否相对固定的,例如某用户的户籍所在地是广东省广州市 那么我们可以将广东省、广州市拆分加密。
    假设广东省加密后字符串为 pwd_gds 广州市加密后字符串为pwd_gzs,
    此时我们前端传入广州市,后端加密后再进行模糊查询 sql语句变成 like %pwd_gzs%

  3. 当然 前面两种方式只是取巧,通常在中型规模的项目就已经不适用了,既然提到拆分,那我们可以联想到分词,所以我们可以使用es,将各词都拆分加密 存入es中 (题外话 es也好 其它存储也罢 一定要设置密码 )

maven依赖冲突问题(jar包版本冲突问题)

场景描述: classNotFound , 这是在项目中,引入版本不正确最经常遇到的问题了。 我们跟进报错类,找到顶部import导包处,假设我们红色涂抹部分报红,我们可以找到前一级目录(红色划线处) ,按住ctrl 键 再鼠标左键点击,找到所在jar包
在这里插入图片描述

解决方案: 将jar包升级(或降级)。
但很多时候,该jar包并不是我们直接通过maven依赖引入的,可能是通过其它组件内部引用的,这个时候我们就可以通过mvn dependency:tree 命令,将控制台打印信息复制到文本编辑器,在文本编辑器搜索 即可知道是哪个父包引入的

在这里插入图片描述
在这里插入图片描述

sql in条件查询时 将结果按照传入顺序排序

场景描述: 例如我们调用外部接口获取id, 再通过id去数据库查询,如果获取一条id 查一次库,是可以保证结果顺序和id传入顺序一致的;那此时我们希望优化一下下,等获取一批id时,再通过in条件查询的形式 :

select xx,xxx,xxxx from t where id in(5,1,4,2,3) 

此时如何保证返回结果顺序与id传入顺序一致呢? 如上伪代码 id=5 时,希望返回记录在第一条

解决方案:

  1. sql层面处理

orcale : order by decode
在这里插入图片描述

mysql : order by field
在这里插入图片描述
2. 如果条件允许 不是直接sql开发,那么推荐是在java代码中去二次处理数据的,循环idList 根据id对比去重新组装结果即可。

数据库主从复制 主从不同步问题

场景描述: 由于网络延迟、负载、、自增主键不一致等等各种原因 导致主从数据不一致
解决方法: 线上真出现了问题,都到了需要集群数据库级别的项目 博主觉得吧 大部分还是手动修复数据吧 出现问题 谁都担不起…

言归正传:

  1. 锁主库 锁为只读状态
  2. 数据导出
  3. 停止从库
  4. 数据导入
  5. 重新开始同步

但是锁主库 停从库 这时候如果有数据来源 非常难处理,这时候最好的方式就是 业务对外公布维护了。

数据库读写分离 读写不一致

场景描述: 读写分离时,读从库时 数据和主库不一致
解决方法: 还是数据同步问题,看业务是否能容忍错误,能就不处理 不能容忍就手动修数据/重新同步。
临时解决方案为:强制路由(强制读取主库) 但博主还是认为,只要不是大面积出现问题,手动修数据都是比较稳妥的方案。

java服务如何作为websocket客户端

场景描述: 有的时候 我们对接供应商/甲方接口,可能会遇到对方给的websocket接口,我们避免在前后端传输之间出现数据丢失问题 可能想在后端自己搭建websocket客户端。 注意是客户端,网上搜java websocket客户端,千篇一律都是搜出作为服务端的教程。
解决方法: 可以使用netty实现,博主目前在写自动重连和发送心跳时 遇到了问题 找了大佬写的比较好的代码 并经过测试 是可用的 具体的代码会单独发博客教程


http://www.kler.cn/a/77.html

相关文章:

  • Photon最新版本PUN 2.29 PREE,在无网的局域网下,无法连接自己搭建的本地服务器
  • web作业
  • 记录一次MySQL:caching_sha2_password报错
  • el-table表格合并某一列
  • Agent | Dify中的两种可选模式
  • 微信小程序map组件所有markers展示在视野范围内
  • 码农饭碗不保——ChatGPT正在取代Coder
  • 扫地机器人(蓝桥杯C/C++)
  • 成本降低90%,OpenAI正式开放ChαtGΡΤ
  • 代码看不懂?ChatGPT 帮你解释,详细到爆!
  • 蔬菜视觉分拣机器人的设计与实现(RoboWork参赛方案)
  • 什么是API?(详细解说)
  • 你写的js性能有多差你知道吗 | js性能优化
  • 【算法入门】字符串基础
  • 【面试题】Python软件工程师能力评估试题(一)
  • ChatGPT相关技术必读论文100篇(2.27日起,几乎每天更新)
  • Stable Diffusion加chilloutmixni真人图片生成模型,AI绘图杀疯了
  • java面试八股文之------Java并发夺命23问
  • 演唱会总是抢不到票?教你用Python制作一个自动抢票脚本
  • uniCloud在线升级APP配置教程
  • 三天吃透MySQL八股文(2023最新整理)
  • 【笔试题】百度+美团
  • 【Linux】冯.诺依曼体系结构与操作系统
  • 为什么北欧的顶级程序员数量远超中国?
  • html实现浪漫的爱情日记(附源码)
  • Java8使用Lambda表达式(流式)快速实现List转map 、分组、过滤等操作