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

做程序时,如果某个查询方法应当返回一条记录,但是查出来多条,是抛异常好还是从多条中取第一条好?我有10年的开发和培训经验。在此期间,我经历了Java、web、Android、H5、大数据、PHP等不同

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

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

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

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

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

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

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

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

调用接口出现异常是怎么回事?

这种订单状态转换是互联网行业非常普遍的问题。这里有一些给你的建议。

1. 首先,订单状态的转换不能丢失。在这种情况下,其中99%需要锁定。您不能完全信任外部调用顺序,也可以引入消息队列,锁定仍然是必要的。无论是使用乐观锁还是悲观锁,redis分布式锁还是zookeeper分布式锁都应该与业务相结合。

2. 锁定会影响效率,但订单、付款、银行流量等,往往在数据正确后才能进行高效处理。我们需要做的是如何在保证数据正确的基础上提高效率……”接口调用的数量仍然很大,许多接口正在等待并发访问”。你把锁调到需要锁的地方了吗。代码优化,将不必要的操作移到锁外,缩小了锁代码的范围,这是效率的又一提高。

3. 最后,当你提到并发队列时,我不知道你指的是“并发队列”还是“消息队列”。不管你的意思是什么,使用这些东西的前提是幂等,解决无序的问题。这基本上涉及到锁定、状态机和补偿机制。

5. 在大中型分布式系统中,所设计的系统和接口应防止重复调用和无序调用。