SqlError 类
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
收集与 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() |
获取错误信息的完整文本。 |