MySqlDatabase.cs 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322
  1. using Common;
  2. using Common.LambdaToSQL;
  3. using Common.Models;
  4. using Dapper;
  5. using Data.Interfaces;
  6. using MySql.Data.MySqlClient;
  7. using System;
  8. using System.Collections.Generic;
  9. using System.Data;
  10. using System.Linq;
  11. using System.Linq.Expressions;
  12. namespace Data.Dapper
  13. {
  14. public class MySqlDatabase : IDatabase
  15. {
  16. private string _connString;
  17. public MySqlDatabase(string connString = "")
  18. {
  19. _connString = connString.IsEmpty() ? ConfigHelper.GetConnectionString("mysql") : connString;
  20. }
  21. #region 属性
  22. /// <summary>
  23. /// 获取 数据库连接串
  24. /// </summary>
  25. private IDbConnection Connection
  26. {
  27. get
  28. {
  29. var dbconnection = new MySqlConnection(_connString);
  30. if (dbconnection.State == ConnectionState.Closed)
  31. {
  32. dbconnection.Open();
  33. }
  34. return dbconnection;
  35. }
  36. }
  37. #endregion 属性
  38. #region 查询
  39. /// <summary>
  40. /// 集合查询
  41. /// </summary>
  42. /// <typeparam name="T"></typeparam>
  43. /// <param name="sql"></param>
  44. /// <param name="para"></param>
  45. /// <returns></returns>
  46. public IEnumerable<T> FindList<T>(string sql, object para = null) where T : class, new()
  47. {
  48. using (var db = Connection)
  49. {
  50. return db.Query<T>(sql, para).ToList();
  51. }
  52. }
  53. /// <summary>
  54. /// 分页集合查询
  55. /// </summary>
  56. /// <typeparam name="T"></typeparam>
  57. /// <param name="condition"></param>
  58. /// <returns></returns>
  59. public PaginationDTO<IEnumerable<T>> FindPageList<T>(string sql, PaginationQuery pagination, object para = null) where T : class, new()
  60. {
  61. using (var db = Connection)
  62. {
  63. var orderBy = "";
  64. if (!string.IsNullOrEmpty(pagination.Sidx))
  65. {
  66. if (pagination.Sord.ToUpper().IndexOf("ASC", StringComparison.Ordinal) + pagination.Sord.ToUpper().IndexOf("DESC", StringComparison.Ordinal) > 0)
  67. {
  68. orderBy = "Order By " + pagination.Sord;
  69. }
  70. else
  71. {
  72. orderBy = "Order By " + pagination.Sidx + " " + pagination.Sord.ToUpper();
  73. }
  74. }
  75. else
  76. {
  77. orderBy = "Order By (Select 0)";
  78. }
  79. var sqls = $@"{sql} {orderBy} limit { (pagination.Page - 1) * pagination.Rows},{ pagination.Rows}";
  80. string selectCountSql = "Select Count(*) From (" + sql + ") AS t";
  81. try
  82. {
  83. return new PaginationDTO<IEnumerable<T>>
  84. {
  85. Data = db.Query<T>(sqls, para).ToList(),
  86. Total = Convert.ToInt32(db.ExecuteScalar(selectCountSql, para)),
  87. Rows = pagination.Rows
  88. };
  89. }
  90. catch (Exception e)
  91. {
  92. return null;
  93. }
  94. }
  95. }
  96. /// <summary>
  97. /// 分页查询-Lambda
  98. /// </summary>
  99. /// <typeparam name="T"></typeparam>
  100. /// <param name="condition"></param>
  101. /// <param name="pagination"></param>
  102. /// <returns></returns>
  103. public PaginationDTO<IEnumerable<T>> FindPageList<T>(Expression<Func<T, bool>> condition, PaginationQuery pagination) where T : class, new()
  104. {
  105. var lambda = new LambdaExpConditions<T>();
  106. lambda.AddAndWhere(condition);
  107. string where = lambda.Where();
  108. string sql = DatabaseCommon<T>.SelectSql(where).ToString();
  109. return FindPageList<T>(sql, pagination);
  110. }
  111. /// <summary>
  112. /// 集合查询(Lambda)
  113. /// </summary>
  114. /// <typeparam name="T"></typeparam>
  115. /// <param name="condition"></param>
  116. /// <returns></returns>
  117. public IEnumerable<T> FindList<T>(Expression<Func<T, bool>> condition) where T : class, new()
  118. {
  119. var lambda = new LambdaExpConditions<T>();
  120. lambda.AddAndWhere(condition);
  121. string where = lambda.Where();
  122. string sql = DatabaseCommon<T>.SelectSql(where).ToString();
  123. return this.FindList<T>(sql);
  124. }
  125. /// <summary>
  126. /// 查询实体对象
  127. /// </summary>
  128. /// <typeparam name="T"></typeparam>
  129. /// <param name="sql"></param>
  130. /// <param name="para"></param>
  131. /// <returns></returns>
  132. public T FindEntity<T>(string sql, object para = null)
  133. {
  134. using (var db = Connection)
  135. {
  136. return db.QueryFirstOrDefault<T>(sql, para);
  137. }
  138. }
  139. /// <summary>
  140. /// 集合查询(Lambda)
  141. /// </summary>
  142. /// <typeparam name="T"></typeparam>
  143. /// <param name="condition"></param>
  144. /// <returns></returns>
  145. public T FindEntity<T>(Expression<Func<T, bool>> condition) where T : class, new()
  146. {
  147. var lambda = new LambdaExpConditions<T>();
  148. lambda.AddAndWhere(condition);
  149. string where = lambda.Where();
  150. string sql = DatabaseCommon<T>.SelectSql(where).ToString();
  151. return FindEntity<T>(sql);
  152. }
  153. /// <summary>
  154. /// 数据条数
  155. /// </summary>
  156. /// <typeparam name="T"></typeparam>
  157. /// <param name="condition"></param>
  158. /// <returns></returns>
  159. public int Count<T>(Expression<Func<T, bool>> condition) where T : class, new()
  160. {
  161. var lambda = new LambdaExpConditions<T>();
  162. lambda.AddAndWhere(condition);
  163. string where = lambda.Where();
  164. string sql = DatabaseCommon<T>.SelectCountSql(where).ToString();
  165. using (var db = Connection)
  166. {
  167. return Convert.ToInt32(db.ExecuteScalar(sql));
  168. }
  169. }
  170. /// <summary>
  171. /// 数据条数
  172. /// </summary>
  173. /// <param name="sql"></param>
  174. /// <param name="para"></param>
  175. /// <returns></returns>
  176. public int Count(string sql, object para)
  177. {
  178. using (var db = Connection)
  179. {
  180. return Convert.ToInt32(db.ExecuteScalar(sql, para));
  181. }
  182. }
  183. #endregion
  184. #region 编辑
  185. /// <summary>
  186. /// 新增sql
  187. /// </summary>
  188. /// <param name="sql">sql语句</param>
  189. /// <param name="para">参数化</param>
  190. public int Insert(string sql, object para = null)
  191. {
  192. using (var db = Connection)
  193. {
  194. return db.Execute(sql, para);
  195. }
  196. }
  197. /// <summary>
  198. /// 实体新增
  199. /// </summary>
  200. /// <param name="sql">sql语句</param>
  201. /// <param name="para">参数化</param>
  202. public int Insert<T>(T model) where T : class, new()
  203. {
  204. using (var db = Connection)
  205. {
  206. string sql = DatabaseCommon<T>.InsertSql().ToString();
  207. return db.Execute(sql, model);
  208. }
  209. }
  210. /// <summary>
  211. /// 批量实体新增
  212. /// </summary>
  213. /// <param name="sql">sql语句</param>
  214. /// <param name="para">参数化</param>
  215. public int Insert<T>(List<T> list) where T : class, new()
  216. {
  217. using (var db = Connection)
  218. {
  219. string sql = DatabaseCommon<T>.InsertSql().ToString();
  220. return db.Execute(sql, list);
  221. }
  222. }
  223. /// <summary>
  224. /// 修改sql
  225. /// </summary>
  226. /// <param name="sql">sql语句</param>
  227. /// <param name="para">参数化</param>
  228. public int Update(string sql, object para = null)
  229. {
  230. using (var db = Connection)
  231. {
  232. return db.Execute(sql, para);
  233. }
  234. }
  235. /// <summary>
  236. /// 修改lammbda
  237. /// </summary>
  238. /// <typeparam name="T"></typeparam>
  239. /// <param name="t"></param>
  240. /// <returns></returns>
  241. public int Update<T>(T t) where T : class, new()
  242. {
  243. using (var db = Connection)
  244. {
  245. string sql = DatabaseCommon<T>.UpdateSql(t).ToString();
  246. if (sql.IsEmpty())
  247. return 0;
  248. return db.Execute(sql, t);
  249. }
  250. }
  251. #endregion
  252. #region 删除
  253. public int Delete(string sql, object para = null)
  254. {
  255. using (var db = Connection)
  256. {
  257. return db.Execute(sql, para);
  258. }
  259. }
  260. /// <summary>
  261. /// 泛型删除
  262. /// </summary>
  263. /// <typeparam name="T"></typeparam>
  264. /// <param name="t"></param>
  265. /// <returns></returns>
  266. public int Delete<T>(T t) where T : class, new()
  267. {
  268. using (var db = Connection)
  269. {
  270. string sql = DatabaseCommon<T>.DeleteSql(t).ToString();
  271. return db.Execute(sql, t);
  272. }
  273. }
  274. /// <summary>
  275. /// 泛型删除
  276. /// </summary>
  277. /// <typeparam name="T"></typeparam>
  278. /// <param name="t"></param>
  279. /// <returns></returns>
  280. public int Delete<T>(int id) where T : class, new()
  281. {
  282. using (var db = Connection)
  283. {
  284. string sql = DatabaseCommon<T>.DeleteSqlById(id).ToString();
  285. return db.Execute(sql);
  286. }
  287. }
  288. #endregion
  289. }
  290. }