SqlError 类

定义

收集与 SQL Server 返回的警告或错误有关的信息。

public ref class SqlError sealed
public sealed class SqlError
[System.Serializable]
public sealed class SqlError
type SqlError = class
[<System.Serializable>]
type SqlError = class
Public NotInheritable Class SqlError
继承
SqlError
属性

示例

以下示例显示 SqlError 集合中的每个 SqlErrorCollection

public static void ShowSqlException(string connectionString)
{
    string queryString = "EXECUTE NonExistantStoredProcedure";

    using (SqlConnection connection = new SqlConnection(connectionString))
    {
        SqlCommand command = new SqlCommand(queryString, connection);
        try
        {
            command.Connection.Open();
            command.ExecuteNonQuery();
        }
        catch (SqlException ex)
        {
            DisplaySqlErrors(ex);
        }
    }
}

private static void DisplaySqlErrors(SqlException exception)
{
    for (int i = 0; i < exception.Errors.Count; i++)
    {
        Console.WriteLine("Index #" + i + "\n" +
            "Error: " + exception.Errors[i].ToString() + "\n");
    }
    Console.ReadLine();
}
Public Sub ShowSqlException(ByVal connectionString As String)
    Dim queryString As String = "EXECUTE NonExistantStoredProcedure"

    Using connection As New SqlConnection(connectionString)
        Dim command As New SqlCommand(queryString, connection)

        Try
            command.Connection.Open()
            command.ExecuteNonQuery()

        Catch ex As SqlException
            DisplaySqlErrors(ex)
        End Try
    End Using
End Sub

Private Sub DisplaySqlErrors(ByVal exception As SqlException)
    Dim i As Integer

    For i = 0 To exception.Errors.Count - 1
        Console.WriteLine("Index #" & i & ControlChars.NewLine & _
            "Error: " & exception.Errors(i).ToString() & ControlChars.NewLine)
    Next i
    Console.ReadLine()
End Sub

注解

此类由.NET Framework数据提供程序创建,用于SQL Server发生错误时。 的 SqlError 实例由 SqlErrorCollection创建和管理,后者又由 SqlException 类创建。

严重级别为 10 或以下的消息为信息性的,并指示问题是由用户输入的信息中的错误导致的。 严重级别从 11 到 16 由用户生成,可由用户更正。 严重级别为 17 到 25 的消息指示存在软件或硬件错误。 发生级别 17、18 或 19 错误时,可以继续工作,尽管可能无法执行特定语句。

当严重级别为 19 或以下时,SqlConnection 将保持打开状态。 当严重度等于或大于 20 时,服务器通常会关闭 SqlConnection。 但是,用户可以重新打开连接并继续操作。 最后两种情况下,执行该命令的方法将生成 SqlException

有关 SQL Server 生成的错误的详细信息,请参阅数据库引擎错误。 有关严重性级别的详细信息,请参阅 数据库引擎错误严重性

属性

Class

获取从 SQL Server 返回的错误的严重程度。

LineNumber

从包含错误的 Transact-SQL 批命令或存储过程中获取行号。

Message

获取对错误进行描述的文本。

Number

获取一个标识错误类型的数字。

Procedure

获取生成错误的存储过程或远程过程调用 (RPC) 的名称。

Server

获取生成错误的 SQL Server 实例的名称。

Source

获取生成错误的提供程序的名称。

State

获取错误的唯一状态代码。

方法

Equals(Object)

确定指定对象是否等于当前对象。

(继承自 Object)
GetHashCode()

作为默认哈希函数。

(继承自 Object)
GetType()

获取当前实例的 Type

(继承自 Object)
MemberwiseClone()

创建当前 Object 的浅表副本。

(继承自 Object)
ToString()

获取错误信息的完整文本。

适用于

另请参阅