1.问题
在更新数据库的数据时,往往我们有这样的一个需求:传入数据库中的数据存在相同key值时就更新key值一样的数据,数据库中没有的数据就进行插入操作,相比于我们传入的数据,数据库中多余的数据就就进行删除操作。
这样的需求很常见,解决的方法也很多,此处我仅介绍一下标题中的方法,用集合来寻找交集以及差集进行更新删除插入操作!
2.解决方法
比如当前数据库中存在3,4,5三个值,而我们前端传入了1,2,3三个值,此时我们就需要对数据库中的数据进行操作,首先寻找交集进行更新,然后寻找差集,将前端传入的不存在于后端的数据进行插入,最后一步也是寻找差集,将数据库中不存在于前端传入的数据进行删除。
确认了大致走向之后事情就变得简单了。
我们创建两个list,A与B,A用来接收前端传入的数据,B存放后端查询出的数据进行对比,使用retainAll()方法,即A.retainAll(B),将交集存放到一个A中,此时A就是我们找到的交集,我们对A进行更新操作即可。
第二部取出我们需要进行插入操作的数据,使用removeAll()方法取差集,即A.removeAll(B),即去除掉A中与B相同的数据,此时我们对A进行插入操作,最后一步也是取差集,即B.removeAll(A),将数据库中不存在于前端传入的数据进行删除操作。
流程结束。
注意!!
在使用retainAll()以及removeAll()方法的时候我们发现这两个集合方法的返回值都是Boolean类型的数据,也就是说使用方法最后的返回值是一种状态,而不是一个集合。
在写程序的时候也因此踩到了一个大坑!注意点:
例:
A.retainAll(B)
这个方法的作用就是将A与B的交集存放在A中
如果集合A的大小发生了改变,返回true,即使两个集合完全没有交集,也会返回true。
如果集合A的大小没有发生改变,返回false,即使两个集合完全相同,也会返回false。
所以,retainAll()的返回值并不能用于判断两个集合是否存在交集,只能用于判断集合大小是否发生改变;
应该通过集合的大小判断两个集合是否有交集。
removeAll()同理!
版权归原作者 violet_evgr 所有, 如有侵权,请联系我们删除。