2016 - 2024

感恩一路有你

java查询功能代码 做程序时,如果某个查询方法应当返回一条记录,但是查出来多条,是抛异常好还是从多条中取第一条好?

浏览量:2520 时间:2021-03-29 02:34:21 作者:admin

做程序时,如果某个查询方法应当返回一条记录,但是查出来多条,是抛异常好还是从多条中取第一条好?

我有10年的开发和培训经验。在此期间,我经历了Java、web、Android、H5、大数据、PHP等不同的发展方向。我也是软件培训公司的金牌讲师。我对回答这个问题很感兴趣。

您已经清楚地解释了这个问题中的要求,“一个查询方法应该返回一条记录,但是可以找到多条记录”!也就是说,您的查询应该只有一个结果,但此时或某个时候,会有多个结果,这意味着您的业务接口可能不满足幂等性的要求。根据幂等设计原理,无论怎样查找,只要参数相同,返回的结果应该是相同的。

那么如何解决这个问题并抛出异常呢?返回到几个中的第一个?

我认为这不是一个完美的解决方案。

这对某些人来说是一个解决方案,但是问题解决了吗?一点也不!问题仍然存在。下次触发此条件时,仍将引发异常。就像说森林里有一只老虎。有一天,它吃人,然后你不解决老虎的问题。你只是在森林里挂了一块牌子,上面写着:小心,里面有老虎!这…

事实上,这不是一个好办法。也许只有一件东西应该被退回。为什么要查询多个项目?您是否检查了数据库中数据的唯一性?你不觉得每次查询多个结果然后得到第一个数据效率很低吗?

所以我们应该从根本上解决问题!为什么会产生多个数据?如果要手动检查数据,则需要手动检查。如果要锁定它,应该尽最大努力确保输入参数相同,结果相同

java输入一个字符串,可包含中文,要求查找其中出现次数最多的字符,并将其出现次数一并输出?

导入java.util.HashMap文件

导入java.util.Iterator

导入java.util.Set

public class Test5

{

public static void main(String[]args)

{

HashMap map=new HashMap()

for(int k=0k&长度)

{

如果(地图。获取(args[k])==null)

{地图输入(args[k],新整数(1))

}

else

{

Integer in=(整数)地图。获取(args[k])

in=新整数(in.int值() 1)

地图输入(args[k],in)

}

集=映射密钥集()

for(Iterator it=集合迭代器() 它。下一个())

{

字符串键=(字符串)它。下一个()

整数值=(整数)地图。获取(键)系统输出打印(key“:”value)

}]}]试试看!

java查询功能代码 java查询数据库并显示 java实现数据库的查询

版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。