- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
在阅读了很多关于 Java 中异常的滥用以及您应该如何让异常在应用程序的不同层中冒泡的内容之后,我已经到了不知道我应该做什么的地步处理我的应用程序可能存在的潜在错误。
基本上,我有一个使用 DAO 模式访问数据库中数据的网络服务。所有数据库操作都可以抛出 SQLException
。从今天开始,我正在使用 try catch 来捕获 SQLException
,然后抛出一个名为 ExceptionDAO
的特定定义的异常,该异常将由 Web 服务处理以返回正确的消息给我的网络服务的用户(移动应用程序)。
在阅读了很多关于异常应该如何异常并且不应在控制流中使用的内容之后,我对我应该如何处理任何错误有了一个复杂的理解:
我也看过 null 模式,但我认为它不太适合这种特殊情况。我还担心不要向用户提供太多信息,而是提供有用且直截了当的信息。事实上,网络服务返回的消息将由移动应用程序使用,然后向最终用户显示消息。
我希望我已经足够清楚我遇到的问题,我期待着您的回答!
最佳答案
返回码适用于C,它的特性中缺少异常处理。对于 Java,请使用异常,检查异常或运行时异常,这是个人喜好问题。
就我个人而言,我讨厌检查异常,因为它们用可能永远不会发生的边界情况信息污染了我的方法签名。但也许你想严格遵守你的类(class)契约(Contract),即使是在这种特殊情况下也是如此。如果是这种情况,请使用已检查的异常。否则,只要检测到异常情况(例如未找到实体、实体已存在等),就让您的方法签名保持平静并抛出运行时异常。
请注意 ExceptionDAO
不是一个好听的名字。它似乎是一个处理异常的 dao。也许像 PersistenceException
这样的东西会更好。
除了命名细节外,我认为您的方法是正确的,但并不理想。理想情况下,您不需要在从 DAO 调用方法的每个方法(或 DAO 的每个方法)中为 SQLException
执行 try/catch
。相反,持久性异常转换机制 会好得多。 Spring ,例如,comes with one by default . Spring 通过代理每个 DAO 并让其代理围绕每个方法调用执行 try/catch
来实现这一点。然后,具有特定 SQL 错误代码的特定 SQLException
被转换为 Spring 自己的 DataAccessException
层次结构。因此,在上层,您最终会得到一个特定的 DataAccessException
,但您不需要在每个方法中执行 try/catch
。
如果您已经在使用 Spring,那么您无事可做,但如果您没有使用它并且有许多 DAO 或许多可能抛出 SQLException
和 的方法你所有的 DAO 都实现了一个接口(interface),那么可能值得努力实现一个代理,它拦截你的 DAO 的所有方法并执行 try/catch
在他们旁边。然后,在这个拦截器的 catch block 中,您将抛出 ExceptionDAO
(请重命名它!),其中包含一条消息,该消息将取决于原始 SQLException
(可能还取决于其 SQL错误代码)。
这种方法的优点是您可以在程序的单个点中处理所有持久性异常。
这个非常相同的概念也可以应用于您的网络层。您可以创建一个代理来拦截每个方法调用并执行 try/catch
围绕它。然后您可以从异常中提取消息并将其发送到响应中(或您认为适合处理的任何内容)。同样,这一切都基于 Spring,这次是在 Spring MVC Exception Handling 中机制。您还可以在这里处理意外异常,即 RuntimeException
并向您的用户提供适当的消息。
同样,优势在于您可以在程序的单个点中处理到达 Web 层的所有异常。
请参阅Proxy javadocs和 this tutorial进一步引用 Java 的代理。
关于java - DAO 模式中的异常与返回码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28652488/
我有组件需要更新客户和客户地址的数据库(通过 JDBC)。从 CustomerDAO 调用 CustomerAddressDAO 是否合适?或者创建一个单独的“CustomerDataManager”
任何人都可以解释MS Access 2007中DAO.Recordset,DAO.Recordsets和DAO.Recordset2之间的区别吗?基本上使用记录集。...举一个例子,使它更清晰。我从“
所以我正在编写一个个人项目来学习 Web 编程,并且我遇到了 DAO 模式。我构建了一些类(模型),并且像几乎所有程序一样,它们是嵌套的(例如:类 Payment 具有对 Author 实例的引用)。
我有一个基本问题。 我一直在创建关注点分离的 DAO。每个 DAO 都专注于上下文中的 BusinessObject。我的问题是如何在另一个 DAO 中使用一个 DAO 方法。我认为这是错误的,但没有
有没有办法使用 Android Room Persistence Library 将 DAO 作为依赖项添加到其他 DAO 中,也许是使用 Dagger2?我试图避免在使用事务对多个表执行操作的 DA
通常,我会尝试以一种完全依赖于自身的方式来构建我的 DAO 类。它们可以与多个表交互,但前提是数据与基础对象相关。例如,假设我有一个约会对象,约会 DAO 从约会表中提取数据。如果约会表是一个服务 i
在学校学习过 Java 后,我对 DAO 模式( Data access object )非常熟悉。然而在工作中我使用.NET。在 .NET 中,经常讨论 DAL( Data Access Layer
我一直在尝试按照以下步骤创建一个通用的 DAO: http://www.ibm.com/developerworks/java/library/j-genericdao/index.html 不过,我
Java EE 中的最佳实践是什么? 在服务(或管理器)类中创建 DAO 类的实例 SalesDAO salesDao = new SalesDAOImpl(); salesDao.findCusto
这有道理吗? 假设我需要从 DB 中获取一个对象,该对象与另一个对象有关系(由 DB 中的外键表示,并由我的域对象中的组合表示)。如果在我的第一个 DAO 中,我为对象 1 获取数据,然后为对象 2
我目前正在为应用程序创建数据访问层。此应用程序最初将连接到 Oracle 数据库,但稍后也会连接到 DB2 数据库。 为了连接到数据库,我将使用 JDBC。在这个时候我正在考虑我的选择。在我看来,我有
我正在 JSF 中设计一些数据“块” 我从每个块的 Java bean 中获取我的数据。 我的问题是我的块从多个表中获取数据。 例如: 描述 的块客户的个人资料 由组成: 客户名称(在表 客户 中)
将 DAO 类与应用程序代码中实际实例化的 DAO 类分开有什么好处,即为什么不在这样的场景中直接实例化 DAO 类: Class CreateIocContainer{ p s v main
我正在为我的 DataNucleus JDO DAO 创建通用 DAO。通用 DAO 将执行获取、更新、删除、创建操作和一些其他通用操作,因此这些实现可以在更具体的 DAO 中进行扩展。 是否有可能以
这可能是一件非常微不足道的事情,但我是一些面向对象模式的新手。 简而言之,在另一个 DAO 中使用一个 DAO 中的方法是一种不好的做法吗?我试图在 DAO 中创建一个实体,但发现仅使用该 DAO 很
我参与了一个 Java 项目,该项目从不同的支付代理获取支付信息,对其进行处理并将其存储到我们的计费系统(数据库)中。 由于我们有不同的代理,因此支付协议(protocol)也不同,因此我们有时有相似
考虑以下 Room DAO @Dao public abstract class JobDao { @Insert public abstract long insert( Job v
我有一个“容器”类,其字段包含在多个数据库表中,我使用 DAO 模式来访问数据。 问题是,我应该为这个“容器”类创建一个 DAO,还是每个表有一个 DAO 并合并它们的数据更好? 最佳答案 您应该根据
我们正在通过 @Service 和 @Component 注释使用 Spring @Autowired 改造一个新的面向服务的架构。 我一直在和我的同事争论不让每个 DAO 都有接口(interfac
我有通用的 DAO: @NoRepositoryBean interface ICrudDao extends Repository { void delete(T deleted);
我是一名优秀的程序员,十分优秀!