C# 将字符串与 SqlExtension 进行比较

Posted

技术标签:

【中文标题】C# 将字符串与 SqlExtension 进行比较【英文标题】:C# Compare a string to a SqlExtension 【发布时间】:2013-08-28 10:17:36 【问题描述】:

我目前正在我的 C# asp.net 页面上使用 SQL。 我在数据库中插入了一个值,但是如果 ID 重复,我会得到这个异常:

"违反 PRIMARY KEY 约束 'PK_Section'。无法在对象 'dbo.Section' 中插入重复键。\r\n语句已终止。"

我想要做的是将异常处理如下:

  if(exception=="Violation of PRIMARY KEY constraint 'PK_Section'. Cannot insert duplicate key in object 'dbo.Section'.\r\nThe statement has been terminated.")
  //update values instead of insert

我的问题是我无法将异常(它是一个字符串)与尝试复制 ID 时得到的那个长“字符串”进行比较。

我是否可以对此进行比较,以便正确解决此错误?

【问题讨论】:

在尝试插入之前检测冲突。这是我们应该做的。 尝试使用 exception.tostring().equals("违反主键约束 'PK_Section'。无法在对象 'dbo.Section' 中插入重复键。\r\n语句已终止。" ) @KingKing 您的解决方案在任何拥有多个用户的系统中存在根本缺陷。 @podiluska transaction 怎么样?我的评论只是反对OP的要求,他想检测是否有任何冲突,但他不知道如何。 【参考方案1】:

您应该捕获SqlException(这可能是您的异常的InnerException)并检查其Number 属性以识别异常。

见http://msdn.microsoft.com/en-us/library/system.data.sqlclient.sqlexception.number.aspx

【讨论】:

【参考方案2】:

我会使用 try catch 块来检查 SqlException。像这样的:

 private bool SaveDocument()
 
        bool saved = false;
        try
        
            Save();
            saved = true;
        
        catch (Exception ex)
        
           string errorTitle = Resources.SaveErrorCaption;
           string errorText = Resources.SaveErrorText;
           Exception initialEx = ex;
            while (ex.InnerException != null)
            
                if (ex.InnerException is SqlException)
                
                    int errorNo = ((SqlException)ex.InnerException).Number;

                    if (errorNo == 2627)
                    
                        errorTitle = Resources.DuplicateEntryErrorTitle;
                        errorText = Resources.DuplicateEntryErrorMessage;
                    
                
                ex = ex.InnerException;
            
            MsgBox.Show(errorTitle, errorText,
                string.Format("01StackTrace:12", initialEx.Message, Environment.NewLine, initialEx.StackTrace),
                MsgBoxButtons.OK, MsgBoxImage.Error);
        
         return saved;

【讨论】:

saved=false; 在 catch 块中是多余的。

以上是关于C# 将字符串与 SqlExtension 进行比较的主要内容,如果未能解决你的问题,请参考以下文章

多线程在我的 c# 程序中执行比顺序执行需要更多时间

C# - Web API - 将枚举序列化为带空格的字符串

你确认C#中TryParse比Parse好?动手测试才知道!

C# 迭代器设计的基本原理(与 C++ 相比)

c#中怎么将string转换成int型

9.11排序与查找——对字符串数组进行排序,将全部的变位词排在相邻的位置