c# – 捕获唯一键冲突的通用方法
发布时间:2020-12-15 07:48:12 所属栏目:百科 来源:网络整理
导读:我使用System.Data.Common.DbCommand将新行插入数据库.关键是,这一行已经存在. try{ [...] DbCommand insertCommand = [...] insertCommand.ExecuteScalar(); [...]}catch (System.Exception exception){ [...] throw;} 如果我将显式捕获System.Data.SqlClie
我使用System.Data.Common.DbCommand将新行插入数据库.关键是,这一行已经存在.
try { [...] DbCommand insertCommand = [...] insertCommand.ExecuteScalar(); [...] } catch (System.Exception exception) { [...] throw; } 如果我将显式捕获System.Data.SqlClient.SqlException,我可以像下面一样评估ErrorNumber. try { //insertion code } catch(SqlException ex) { if(ex.Number == 2627) { //Violation of primary key. Handle Exception } } SqlException上下文中的ErrorNumber 2627意味着违反唯一键.见https://msdn.microsoft.com/en-us/library/ms151757%28v=sql.110%29.aspx 到现在为止还挺好.因为我正在使用DbCommand,因此使用不同类型的关系数据库管理系统,我正在寻找一种更通用的方式来捕获这种违反唯一键约束的行为. 感谢帮助. 解决方法
我担心没有内置的通用解决方案.作为一种解决方法,您可以为Execute …创建一个包装器:
public static int ExecuteWithNiceExceptions(this IDbCommand cmd) { try { return cmd.ExecuteNonQuery(); } catch(SqlException ex) { if (ex.Number == 2627) { throw new PrimaryKeyViolationException(cmd,ex); } else { throw; } } catch (OleDbException ex) { ... } ... } 这样,您可以将不同的,特定于实现的异常“转换”为通用的,有意义的异常. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |