【java】 java开发中 常遇到的各种难点 思路方案 | 您所在的位置:网站首页 › clear用法举例 › 【java】 java开发中 常遇到的各种难点 思路方案 |
文章目录
逻辑删除如何建立唯一索引唯一索引失效问题加密字段模糊查询问题maven依赖冲突问题(jar包版本冲突问题)sql in条件查询时 将结果按照传入顺序排序
作为一个开发人员 总会遇到各种难题 本文列举博主 遇见/想到 的例子 ,也希望同学们可以在评论区举例交流 共同进步~ 逻辑删除如何建立唯一索引场景描述: 比如我们有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 共同设置为唯一索引 可以解决该问题。 唯一索引失效问题场景描述: 人员姓名和电话 组成唯一索引 。 解决方案: 唯一索引的字段设置为非空,因为空是允许重复的 ( 不管单独将某一个字段设置为唯一索引 还是多个字段组合成唯一索引 都一样的) 加密字段模糊查询问题场景描述: 用户敏感信息,例如手机号 身份证 户籍所在地 入库时,我们通常会加密, 这时需要模糊查询 解决方案: 数据量少时,例如只是一个公司内部系统的人员表,可以全表查询 并解密,在java代码中过滤 (如果遇到要分页,那得好好考虑怎么处理分页问题了) 与业务/产品沟通,看搜索的字数是否相对固定的,例如某用户的户籍所在地是广东省广州市 那么我们可以将广东省、广州市拆分加密。 假设广东省加密后字符串为 pwd_gds 广州市加密后字符串为pwd_gzs, 此时我们前端传入广州市,后端加密后再进行模糊查询 sql语句变成 like %pwd_gzs% 当然 前面两种方式只是取巧,通常在中型规模的项目就已经不适用了,既然提到拆分,那我们可以联想到分词,所以我们可以使用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 时,希望返回记录在第一条 解决方案: sql层面处理orcale : order by decode mysql : order by field |
今日新闻 |
推荐新闻 |
专题文章 |
CopyRight 2018-2019 实验室设备网 版权所有 |