最近在项目中碰到了这么一个需求,一个JavaWeb项目,数据库用的是Oracle。业务上有一个对一张表的操作功能,当时设置了两个字段联合的唯一约束。由于前断没有对重复字段的校验,需要在插入时如果碰到唯一约束重复的时候在报文中抛出异常信息的描述,这是就需要获取详细的Oracle错误并添加错误描述信息。众所周知,oracle的错误码返回都是以ORA-xxxxx开头的,所以获取方式如下所示:
- 从抛出的异常中拿除去ORA-打头的错误码
//获取Oracle的错误码.
// @return 错误码 如00001是主键冲突
public static String getOraCode(Exception e) {
if (e == null) {
return "";
}
String tmp = e.getMessage();
int index = tmp.toUpperCase().indexOf("ORA-");
if (index != -1) {
return tmp.substring(index + 4, index + 9);
}
return "";
}
- 对错误码进行判断
public void addAccFlow(Map<String,Object> map) throws Exception {
try {
generalAccountingParanService.add(map);
} catch (Exception e) {
String flag = getOraCode(e);
//主键冲突
if (flag.equals("00001")) {
throw new BusinessException(MsgConstant_26001);
}
throw ex;
}
}
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于