IDatabaseHelper.cs 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. using Azylee.Core.AppUtils.AppConfigUtils.AppConfigModels;
  2. using Azylee.Core.DbUtils.DbModels;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Data;
  6. using System.Linq;
  7. using System.Text;
  8. namespace Azylee.Core.DbUtils.DbInterface
  9. {
  10. /// <summary>
  11. /// 数据库工具类接口定义
  12. /// </summary>
  13. public interface IDatabaseHelper : IDisposable
  14. {
  15. /// <summary>
  16. /// 创建并打开连接
  17. /// 注意:通常在构造函数中直接调用
  18. /// </summary>
  19. /// <returns></returns>
  20. bool OpenConnect();
  21. /// <summary>
  22. /// 测试连接
  23. /// </summary>
  24. /// <returns></returns>
  25. bool TestConnect();
  26. /// <summary>
  27. /// 普通查询
  28. /// </summary>
  29. /// <param name="sql"></param>
  30. /// <returns></returns>
  31. DataTable Select(string sql);
  32. /// <summary>
  33. /// 普通查询(异常时抛出异常,不能内部处理掉)
  34. /// </summary>
  35. /// <param name="sql"></param>
  36. /// <returns></returns>
  37. DataTable SelectWithException(string sql);
  38. /// <summary>
  39. /// 查询所有数据库名称
  40. /// </summary>
  41. /// <returns></returns>
  42. DataTable SchemaList();
  43. /// <summary>
  44. /// 查询表字段信息列表
  45. /// </summary>
  46. /// <returns></returns>
  47. DataTable ColumnList(string database, string schema,string table);
  48. /// <summary>
  49. /// 执行文件
  50. /// </summary>
  51. /// <param name="SqlFile">执行文件路径</param>
  52. /// <param name="action">执行后动作(执行语句,是否成功,影响行数,异常提示信息)</param>
  53. /// <returns></returns>
  54. Tuple<bool, int, string> ExecuteFile(string SqlFile, Action<string, bool, int, string> action);
  55. /// <summary>
  56. /// 执行文件SQL(一段SQL脚本)
  57. /// </summary>
  58. /// <param name="sql"></param>
  59. /// <returns></returns>
  60. Tuple<bool, int, string> ExecuteFileSql(string sql);
  61. /// <summary>
  62. /// 执行SQL(返回影响行数)
  63. /// </summary>
  64. /// <param name="sql"></param>
  65. /// <returns></returns>
  66. int ExecuteNonQuery(string sql);
  67. /// <summary>
  68. /// 查询表清单
  69. /// </summary>
  70. /// <param name="key"></param>
  71. /// <returns></returns>
  72. List<DbmTable> QueryTables(string key = "");
  73. /// <summary>
  74. /// 查询表字段列表
  75. /// </summary>
  76. /// <param name="database"></param>
  77. /// <param name="schema"></param>
  78. /// <param name="table"></param>
  79. /// <returns></returns>
  80. List<DbmColumn> QueryColumns(string database, string schema, string table);
  81. }
  82. }