You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

80 lines
2.7 KiB

4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Text;
  4. namespace Apewer.Source
  5. {
  6. /// <summary>表示在执行 SQL 语句执行过程中发生的错误。</summary>
  7. [Serializable]
  8. public sealed class SqlException : Exception
  9. {
  10. const string EmptyMessage = "(无消息)";
  11. string _msg = null;
  12. string _sql = null;
  13. object _parameters = null;
  14. /// <summary>获取描述当前异常的消息。</summary>
  15. public override string Message { get => _msg; }
  16. /// <summary>获取引发异常的 SQL 语句。</summary>
  17. public string Statement { get => _sql; }
  18. /// <summary>获取引发异常的 SQL 参数。</summary>
  19. public object Parameters { get => _parameters; }
  20. /// <summary>初始化 <see cref="SqlException"/> 类的新实例。</summary>
  21. /// <param name="message">描述当前异常的消息。</param>
  22. /// <param name="statement">附带 SQL 语句。</param>
  23. /// <param name="parameters">附带 SQL 参数。</param>
  24. public SqlException(string message, string statement = null, object parameters = null)
  25. {
  26. _msg = string.IsNullOrEmpty(message) ? EmptyMessage : message;
  27. _sql = statement;
  28. _parameters = parameters;
  29. }
  30. /// <summary>初始化 <see cref="SqlException"/> 类的新实例。</summary>
  31. /// <param name="query">用于获取消息的查询结果。</param>
  32. /// <param name="statement">附带 SQL 语句。</param>
  33. /// <param name="parameters">附带 SQL 参数。</param>
  34. public SqlException(IQuery query, string statement = null, object parameters = null)
  35. {
  36. if (query == null)
  37. {
  38. _msg = "查询结果实例无效。";
  39. _sql = statement;
  40. return;
  41. }
  42. _msg = query.Message;
  43. if (string.IsNullOrEmpty(Message)) _msg = EmptyMessage;
  44. _sql = statement;
  45. _parameters = parameters;
  46. }
  47. /// <summary>初始化 <see cref="SqlException"/> 类的新实例。</summary>
  48. /// <param name="execute">用于获取消息的执行结果。</param>
  49. /// <param name="statement">附带 SQL 语句。</param>
  50. /// <param name="parameters">附带 SQL 参数。</param>
  51. public SqlException(IExecute execute, string statement = null, object parameters = null)
  52. {
  53. if (execute == null)
  54. {
  55. _msg = "执行结果实例无效。";
  56. return;
  57. }
  58. _msg = execute.Message;
  59. if (string.IsNullOrEmpty(Message)) _msg = EmptyMessage;
  60. _sql = statement;
  61. _parameters = parameters;
  62. }
  63. }
  64. }