MongoHelper.cs 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271
  1. 
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Configuration;
  5. using System.Linq;
  6. using System.Linq.Expressions;
  7. using System.Text;
  8. using System.Threading.Tasks;
  9. using MongoDB;
  10. using MongoDB.Driver;
  11. using MongoDB.Driver.Builders;
  12. namespace DataMipCRM.Common
  13. {
  14. public class MongoDBHelper<T>
  15. {
  16. private static readonly string connectionString = ConfigurationManager.AppSettings["mongodbServerList"];
  17. static MongoClientSettings setting = null;
  18. MongoServer server = null;
  19. public string tableName = "person";
  20. public string databaseName = "Mdemo";
  21. static MongoDBHelper()
  22. {
  23. var ips = connectionString.Split(';');
  24. var servicesList = new List<MongoServerAddress>();
  25. foreach (var ip in ips)
  26. {
  27. var host = ip.Split(':')[0];
  28. var port = Convert.ToInt32(ip.Split(':')[1]);
  29. servicesList.Add(new MongoServerAddress(host, port));
  30. }
  31. setting = new MongoClientSettings();
  32. setting.ReplicaSetName = "datamip";
  33. //集群中的服务器列表
  34. setting.Servers = servicesList;
  35. }
  36. public MongoDBHelper(string databaseName, string tableName)
  37. {
  38. this.databaseName = databaseName;
  39. this.tableName = tableName;
  40. server = new MongoClient(setting).GetServer();
  41. }
  42. /// <summary>
  43. ///
  44. /// </summary>
  45. /// <param name="func"></param>
  46. /// <returns></returns>
  47. public bool Remove(Expression<Func<T, bool>> func)
  48. {
  49. try
  50. {
  51. var database = server.GetDatabase(databaseName);
  52. var collection = database.GetCollection<T>(tableName);
  53. var query = Query<T>.Where(func);
  54. var result = collection.Remove(query);
  55. return result.Response["ok"].AsInt32 > 0 ? true : false;
  56. }
  57. catch (Exception ex)
  58. {
  59. return false;
  60. }
  61. }
  62. /// <summary>
  63. ///
  64. /// </summary>
  65. /// <returns></returns>
  66. public bool RemoveAll()
  67. {
  68. try
  69. {
  70. var database = server.GetDatabase(databaseName); //mongodb中的数据库
  71. var collection = database.GetCollection<T>(tableName);
  72. var result = collection.RemoveAll();
  73. return result.Response["ok"].AsInt32 > 0 ? true : false;
  74. }
  75. catch (Exception ex)
  76. {
  77. return false;
  78. }
  79. }
  80. #region 单条插入
  81. /// <summary>
  82. /// 单条插入
  83. /// </summary>
  84. /// <typeparam name="T"></typeparam>
  85. /// <param name="t"></param>
  86. public bool Insert(T t)
  87. {
  88. try
  89. {
  90. var database = server.GetDatabase(databaseName); //mongodb中的数据库
  91. var collection = database.GetCollection<T>(tableName);
  92. var result = collection.Insert(t);
  93. return result.DocumentsAffected > 0;
  94. }
  95. catch (Exception ex)
  96. {
  97. return false;
  98. }
  99. }
  100. #endregion
  101. #region 单条覆盖,如果不存在插入,如果存在覆盖
  102. /// <summary>
  103. /// 单条覆盖,如果不存在插入,如果存在覆盖
  104. /// </summary>
  105. /// <typeparam name="T"></typeparam>
  106. /// <param name="t"></param>
  107. public bool Save(T t)
  108. {
  109. try
  110. {
  111. var database = server.GetDatabase(databaseName); //mongodb中的数据库
  112. var collection = database.GetCollection<T>(tableName);
  113. var result = collection.Save(t);
  114. return result.DocumentsAffected > 0;
  115. }
  116. catch (Exception ex)
  117. {
  118. return false;
  119. }
  120. }
  121. #endregion
  122. #region 批量插入
  123. /// <summary>
  124. /// 批量插入
  125. /// </summary>
  126. /// <typeparam name="T"></typeparam>
  127. /// <param name="t"></param>
  128. public bool Insert(IEnumerable<T> t)
  129. {
  130. try
  131. {
  132. var database = server.GetDatabase(databaseName); //mongodb中的数据库
  133. var collection = database.GetCollection<T>(tableName);
  134. collection.InsertBatch(t);
  135. return true;
  136. }
  137. catch (Exception ex)
  138. {
  139. return false;
  140. }
  141. }
  142. #endregion
  143. #region 批量查询
  144. public List<T> Search(Expression<Func<T, bool>> func, bool forcemaster = false)
  145. {
  146. var list = new List<T>();
  147. try
  148. {
  149. //是否强制使用 “主服务器”
  150. if (forcemaster)
  151. {
  152. var database = server.GetDatabase(databaseName); //mongodb中的数据库
  153. var collection = database.GetCollection<T>(tableName);
  154. list = collection.Find(Query<T>.Where(func)).ToList();
  155. }
  156. else
  157. {
  158. var database = server.GetDatabase(databaseName); //mongodb中的数据库
  159. var collection = database.GetCollection<T>(tableName);
  160. list = collection.Find(Query<T>.Where(func)).ToList();
  161. }
  162. }
  163. catch (Exception ex)
  164. {
  165. throw;
  166. }
  167. return list;
  168. }
  169. #endregion
  170. #region 单条查询
  171. /// <summary>
  172. /// 单条查询
  173. /// </summary>
  174. /// <param name="func"></param>
  175. /// <param name="forcemaster">是否强制使用 “主服务器”</param>
  176. /// <returns></returns>
  177. public T SearchOne(Expression<Func<T, bool>> func, bool forcemaster = false)
  178. {
  179. T t = default(T);
  180. try
  181. {
  182. if (forcemaster)
  183. {
  184. var database = server.GetDatabase(databaseName); //mongodb中的数据库
  185. var collection = database.GetCollection<T>(tableName);
  186. t = collection.FindOne(Query<T>.Where(func));
  187. }
  188. else
  189. {
  190. var database = server.GetDatabase(databaseName); //mongodb中的数据库
  191. var collection = database.GetCollection<T>(tableName);
  192. t = collection.FindOne(Query<T>.Where(func));
  193. }
  194. return t;
  195. }
  196. catch (Exception ex)
  197. {
  198. return t;
  199. }
  200. }
  201. #endregion
  202. /// <summary>
  203. /// 查询所有数据
  204. /// </summary>
  205. /// <returns></returns>
  206. public List<T> SearchAll()
  207. {
  208. var list = new List<T>();
  209. try
  210. {
  211. var database = server.GetDatabase(databaseName); //mongodb中的数据库
  212. var collection = database.GetCollection<T>(tableName);
  213. list = collection.FindAll().ToList();
  214. return list;
  215. }
  216. catch (Exception ex)
  217. {
  218. return list;
  219. }
  220. }
  221. }
  222. }