欢迎您来到懒之才-站长的分享平台!   学会偷懒,并懒出境界是提高工作效率最有效的方法!
首页 > 经验分享 > 数据库 > 数据库级别判断数据重复

数据库级别判断数据重复

2018-07-24 583 收藏 0 赞一个 0 真差劲 0 去评论

建立表语句 在数据库添加一个表并对字段添加唯一约束。msdn上认为建唯一约束会自动创建相应的唯一索引。

USE AdventureWorks2012;
GO
CREATE TABLE Production.TransactionHistoryArchive4
(
    TransactionID int NOT NULL,
    CONSTRAINT AK_TransactionID UNIQUE(TransactionID)
);
GO

插入测试sql   

INSERT INTO [db].[dbo].[TransactionHistoryArchive4]
([TransactionID])
VALUES
(1)
GO

这时候我写的测试语句 当我第一次执行时 显示 (1 行受影响)数据库数据正常

第二次执行语句时就会报错

消息 2627,级别 14,状态 1,第 1 行
违反了 UNIQUE KEY 约束 'AK_TransactionID'。不能在对象 'dbo.TransactionHistoryArchive4' 中插入重复键。
语句已终止。

消息2627是我需要的信息。因为C#中提供了SqlException来捕获数据库发生的异常。根据消息id就可以判断出错误类型 好久不写ado代码了

try
{
    using (SqlConnection connection = new SqlConnection(connectionString))
    {
        SqlCommand command = new SqlCommand(queryString, connection);
        command.Connection.Open();
        command.ExecuteNonQuery();
    }
}
catch (SqlException sqlException)
{
    if (sqlException.Number == 2627)
        errmsg = "errmsg";
    else
        errmsg = "其他异常";
}

遇见了就不要错过

一、推荐使用迅雷或快车等多线程下载软件下载本站资源。

二、未登录会员无法下载,登录后可获得更多便利功能,若未注册,请先注册。

三、如果服务器暂不能下载请稍后重试!总是不能下载,请点我报错 ,谢谢合作!

四、本站大部分资源是网上搜集或私下交流学习之用,任何涉及商业盈利目的均不得使用,否则产生的一切后果将由您自己承担!本站将不对任何资源负法律责任.如果您发现本站有部分资源侵害了您的权益,请速与我们联系,我们将尽快处理.

五、如有其他问题,请加网站设计交流群(点击这里查看交流群 )进行交流。

六、如需转载本站资源,请注明转载来自并附带链接

七、本站部分资源为加密压缩文件,统一解压密码为:www.aizhanzhe.com

大家评论