DbConfig.cs 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. using ZhonTai.Admin.Core.Consts;
  2. using DataType = FreeSql.DataType;
  3. namespace ZhonTai.Admin.Core.Configs;
  4. /// <summary>
  5. /// 数据库配置
  6. /// </summary>
  7. public class DbConfig
  8. {
  9. /// <summary>
  10. /// 数据库注册键
  11. /// </summary>
  12. public string Key { get; set; } = DbKeys.AppDb;
  13. /// <summary>
  14. /// 程序集名称
  15. /// </summary>
  16. public string[] AssemblyNames { get; set; }
  17. /// <summary>
  18. /// 数据库类型
  19. /// </summary>
  20. public DataType Type { get; set; } = DataType.Sqlite;
  21. /// <summary>
  22. /// 数据库字符串
  23. /// </summary>
  24. public string ConnectionString { get; set; } = "Data Source=|DataDirectory|\\admindb.db; Pooling=true;Min Pool Size=1";
  25. /// <summary>
  26. /// 指定程序集
  27. /// </summary>
  28. public string ProviderType { get; set; }
  29. /// <summary>
  30. /// 生成数据
  31. /// </summary>
  32. public bool GenerateData { get; set; } = false;
  33. /// <summary>
  34. /// 同步结构
  35. /// </summary>
  36. public bool SyncStructure { get; set; } = false;
  37. /// <summary>
  38. /// 同步结构脚本
  39. /// </summary>
  40. public bool SyncStructureSql { get; set; } = false;
  41. /// <summary>
  42. /// 同步数据
  43. /// </summary>
  44. public bool SyncData { get; set; } = false;
  45. /// <summary>
  46. /// 同步数据监听Curd操作
  47. /// </summary>
  48. public bool SyncDataCurd { get; set; } = false;
  49. /// <summary>
  50. /// 同步更新数据
  51. /// </summary>
  52. public bool SysUpdateData { get; set; } = false;
  53. /// <summary>
  54. /// 同步数据地址
  55. /// </summary>
  56. public string SyncDataPath { get; set; } = "InitData/Admin";
  57. /// <summary>
  58. /// 同步数据包含表列表
  59. /// </summary>
  60. public string[] SyncDataIncludeTables { get; set; }
  61. /// <summary>
  62. /// 同步数据排除表列表
  63. /// </summary>
  64. public string[] SyncDataExcludeTables { get; set; }
  65. /// <summary>
  66. /// 建库
  67. /// </summary>
  68. public bool CreateDb { get; set; } = false;
  69. /// <summary>
  70. /// 建库连接字符串
  71. /// </summary>
  72. public string CreateDbConnectionString { get; set; }
  73. /// <summary>
  74. /// 建库脚本
  75. /// </summary>
  76. public string CreateDbSql { get; set; }
  77. /// <summary>
  78. /// 监听所有操作
  79. /// </summary>
  80. public bool MonitorCommand { get; set; } = false;
  81. /// <summary>
  82. /// 监听Curd操作
  83. /// </summary>
  84. public bool Curd { get; set; } = false;
  85. /// <summary>
  86. /// 空闲时间(分),默认10分钟,设置idleTime=0则不自动回收
  87. /// </summary>
  88. public int? IdleTime { get; set; } = 10;
  89. /// <summary>
  90. /// 多数据库
  91. /// </summary>
  92. public DbConfig[] Dbs { get; set; }
  93. /// <summary>
  94. /// 读写分离从库列表
  95. /// </summary>
  96. public SlaveDb[] SlaveList { get; set; }
  97. }
  98. /// <summary>
  99. /// 读写分离从库
  100. /// </summary>
  101. public class SlaveDb
  102. {
  103. /// <summary>
  104. /// 数据库类型
  105. /// </summary>
  106. public int Weight { get; set; } = 1;
  107. /// <summary>
  108. /// 数据库连接字符串
  109. /// </summary>
  110. public string ConnectionString { get; set; }
  111. }