IRedisHelper.cs 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471
  1. using StackExchange.Redis;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. namespace OASystem.RedisRepository.RedisAsyncHelper
  8. {
  9. /// <summary>
  10. /// 异步方法接口
  11. /// 存入数据均为方法内部序列化后的byte,所以取数据的时候需要反序列化时,请指定正确的数据类型
  12. /// </summary>
  13. public partial interface IRedisHelper
  14. {
  15. #region Redis数据类型—String
  16. /// <summary>
  17. /// 将任何数据以redis string存储
  18. /// </summary>
  19. /// <typeparam name="T"></typeparam>
  20. /// <param name="key"></param>
  21. /// <param name="value"></param>
  22. /// <param name="timeout"></param>
  23. /// <returns></returns>
  24. Task<bool> StringSetAsync<T>(string key, T value, TimeSpan? timeout = null);
  25. /// <summary>
  26. /// 对数值进行减法操作,默认-1
  27. /// </summary>
  28. /// <param name="key"></param>
  29. /// <param name="value"></param>
  30. /// <returns>操作后的结果</returns>
  31. Task<long> StringDecrementAsync(string key, long value = 1L);
  32. /// <summary>
  33. /// 对数值进行加法操作,默认+1
  34. /// </summary>
  35. /// <param name="key"></param>
  36. /// <param name="value"></param>
  37. /// <returns>操作后的结果</returns>
  38. Task<long> StringIncrementAsync(string key, long value = 1L);
  39. /// <summary>
  40. /// 从redis string中以指定类型取出
  41. /// </summary>
  42. /// <typeparam name="T"></typeparam>
  43. /// <param name="key"></param>
  44. /// <returns></returns>
  45. Task<T> StringGetAsync<T>(string key);
  46. /// <summary>
  47. /// 读取 string 键的原始文本(UTF-8)。不做 BinaryFormatter 反序列化,适用于存 JSON 等纯文本。
  48. /// </summary>
  49. Task<string?> StringGetRawAsync(string key);
  50. #endregion
  51. #region Redis数据类型—Hash
  52. /// <summary>
  53. /// 向Hash key中存储任意类型任意值
  54. /// </summary>
  55. /// <typeparam name="T"></typeparam>
  56. /// <param name="key"></param>
  57. /// <param name="field"></param>
  58. /// <param name="value"></param>
  59. /// <returns>是否成功</returns>
  60. Task<bool> HashSetAsync<T>(string key, string field, T value);
  61. /// <summary>
  62. /// 批量 向Hash key中存储任意类型任意值
  63. /// </summary>
  64. /// <typeparam name="T"></typeparam>
  65. /// <param name="key"></param>
  66. /// <param name="hashFields"></param>
  67. /// <returns>无返回值</returns>
  68. Task HashMultiSetAsync<T>(string key, Dictionary<string, T> hashFields);
  69. /// <summary>
  70. /// 对指定hash key中制定field做数量增加操作 默认自增1
  71. /// 如果此操作前key不存在 则创建。 如果此操作前该field不存在或者非数字 则先被置0,再被继续操作
  72. /// </summary>
  73. /// <param name="key"></param>
  74. /// <param name="field"></param>
  75. /// <param name="incrCount"></param>
  76. /// <returns>操作后的结果</returns>
  77. Task<long> HashIncrementAsync(string key, string field, long incrCount = 1);
  78. /// <summary>
  79. /// 对指定hash key中制定field做数量增加操作 默认自减1
  80. /// 如果此操作前key不存在 则创建。 如果此操作前该field不存在或者非数字 则先被置0,再被继续操作
  81. /// </summary>
  82. /// <param name="key"></param>
  83. /// <param name="field"></param>
  84. /// <param name="decrCount"></param>
  85. /// <returns>操作后的结果</returns>
  86. Task<long> HashDecrementAsync(string key, string field, long decrCount = 1);
  87. /// <summary>
  88. /// 从指定Hash中 删除指定field
  89. /// 如果key或者field不存在,则false
  90. /// </summary>
  91. /// <param name="key"></param>
  92. /// <param name="field"></param>
  93. /// <returns>是否成功</returns>
  94. Task<bool> HashDeleteFieldAsync(string key, string field);
  95. /// <summary>
  96. /// 从指定Hash key中 批量删除指定field
  97. /// 如果key或者field不存在,则false
  98. /// </summary>
  99. /// <param name="key"></param>
  100. /// <param name="fields"></param>
  101. /// <returns>移除数量</returns>
  102. Task<long> HashMultiDeleteFieldAsync(string key, List<string> fields);
  103. /// <summary>
  104. /// 从指定Hash key中获取指定field值
  105. /// </summary>
  106. /// <typeparam name="T"></typeparam>
  107. /// <param name="key"></param>
  108. /// <param name="field"></param>
  109. /// <returns></returns>
  110. Task<T> HashGetAsync<T>(string key, string field);
  111. /// <summary>
  112. /// 从指定Hash key中判断field是否存在
  113. /// </summary>
  114. /// <param name="key"></param>
  115. /// <param name="field"></param>
  116. /// <returns></returns>
  117. Task<bool> HashFieldExistAsync(string key, string field);
  118. /// <summary>
  119. /// 获取指定Hash key中的所有field的值
  120. /// </summary>
  121. /// <typeparam name="T"></typeparam>
  122. /// <param name="key"></param>
  123. /// <returns></returns>
  124. Task<List<T>> HashValuesAsync<T>(string key);
  125. /// <summary>
  126. /// 获取指定Hash key中所有 field名称及其Value
  127. /// </summary>
  128. /// <typeparam name="T"></typeparam>
  129. /// <param name="key"></param>
  130. /// <returns></returns>
  131. Task<Dictionary<string, T>> HashGetAllAsync<T>(string key);
  132. /// <summary>
  133. /// 获取指定Hash key中所有field
  134. /// </summary>
  135. /// <param name="key"></param>
  136. /// <returns></returns>
  137. Task<List<string>> HashFieldsAsync(string key);
  138. #endregion
  139. #region Redis数据类型—List
  140. /// <summary>
  141. /// 在指定pivot后插入value, 如果pivot不存在,则返回-1, 如果key不存在,则返回0
  142. /// 如果存在多个相同指定的的pivot,则插入第一个指定pivot后面.
  143. /// 即链表从左向右查找,遇到指定pivot,则确定位置
  144. /// </summary>
  145. /// <typeparam name="T"></typeparam>
  146. /// <param name="key"></param>
  147. /// <param name="pivot">list中的一个值</param>
  148. /// <param name="value"></param>
  149. /// <returns></returns>
  150. Task<long> ListInsertAfterAsync<T>(string key, string pivot, T value);
  151. /// <summary>
  152. /// 在指定pivot前插入value, 如果pivot不存在,则返回-1, 如果key不存在,则返回0
  153. /// 如果存在多个相同指定的的pivot,则插入第一个指定pivot前面.
  154. /// 即链表从左向右查找,遇到指定pivot,则确定位置
  155. /// </summary>
  156. /// <typeparam name="T"></typeparam>
  157. /// <param name="key"></param>
  158. /// <param name="pivot"></param>
  159. /// <param name="value"></param>
  160. /// <returns></returns>
  161. Task<long> ListInsertBeforeAsync<T>(string key, string pivot, T value);
  162. /// <summary>
  163. /// 从链表左侧弹出第一个元素(弹出能获取到该元素并且被删除)
  164. /// 如果key不存在 或者链表为空 则为null
  165. /// </summary>
  166. /// <typeparam name="T"></typeparam>
  167. /// <param name="key"></param>
  168. /// <returns></returns>
  169. Task<T> ListLeftPopAsync<T>(string key);
  170. /// <summary>
  171. /// 从链表左侧增加一个元素,key不存在则被创建
  172. /// </summary>
  173. /// <typeparam name="T"></typeparam>
  174. /// <param name="key"></param>
  175. /// <param name="value"></param>
  176. /// <returns>返回操作后的链表长度</returns>
  177. Task<long> ListLeftPushAsync<T>(string key, T value);
  178. /// <summary>
  179. /// 从链表左侧批量增加元素,如果 a b c 则c会在链表左侧第一位 b第二位 a第三位
  180. /// </summary>
  181. /// <typeparam name="T"></typeparam>
  182. /// <param name="key"></param>
  183. /// <param name="values"></param>
  184. /// <returns>返回操作后的链表长度</returns>
  185. Task<long> ListLeftMultiPushAsync<T>(string key, List<T> values);
  186. /// <summary>
  187. /// 获取链表长度,不存在key则为0
  188. /// </summary>
  189. /// <typeparam name="T"></typeparam>
  190. /// <param name="key"></param>
  191. /// <returns></returns>
  192. Task<long> ListLengthAsync<T>(string key);
  193. /// <summary>
  194. /// 获取链表中所有数据,从左侧start开始到stop结束,从0—-1则认为获取全部,默认获取全部
  195. /// start为负数则代表从链表右侧开始,-1为右侧第一位,-2为右侧第二位
  196. /// start要小于stop,否则返回null
  197. /// </summary>
  198. /// <typeparam name="T"></typeparam>
  199. /// <param name="key"></param>
  200. /// <param name="start"></param>
  201. /// <param name="stop"></param>
  202. /// <returns></returns>
  203. Task<List<T>> ListRangeAsync<T>(string key, long start = 0L, long stop = -1L);
  204. /// <summary>
  205. /// 从链表中一处count数量的value. count大于0则从左至右,count小于0则从右至左,count=0则移除全部
  206. /// </summary>
  207. /// <typeparam name="T"></typeparam>
  208. /// <param name="key"></param>
  209. /// <param name="value"></param>
  210. /// <param name="count"></param>
  211. /// <returns></returns>
  212. Task<long> ListRemoveAsync<T>(string key, T value, long count = 0L);
  213. /// <summary>
  214. /// 从右侧弹出第一个元素(弹出能获取到该元素并且被删除)
  215. /// </summary>
  216. /// <typeparam name="T"></typeparam>
  217. /// <param name="key"></param>
  218. /// <returns></returns>
  219. Task<T> ListRightPopAsync<T>(string key);
  220. /// <summary>
  221. /// 从链表右侧加入元素,如果 rpush a b c 则c为右侧第一位 b第二位 c第三位
  222. /// </summary>
  223. /// <typeparam name="T"></typeparam>
  224. /// <param name="key"></param>
  225. /// <param name="value"></param>
  226. /// <returns></returns>
  227. Task<long> ListRightPushAsync<T>(string key, T value);
  228. /// <summary>
  229. /// 从右侧批量插入,和左侧相反
  230. /// </summary>
  231. /// <typeparam name="T"></typeparam>
  232. /// <param name="key"></param>
  233. /// <param name="values"></param>
  234. /// <returns></returns>
  235. Task<long> ListRightMultiPushAsync<T>(string key, List<T> values);
  236. /// <summary>
  237. /// 在链表指定索引处,插入元素
  238. /// 正数索引从0开始,代表左侧。负数从-1开始 代表从右侧。-1为右侧第一位
  239. /// </summary>
  240. /// <typeparam name="T"></typeparam>
  241. /// <param name="key"></param>
  242. /// <param name="index"></param>
  243. /// <param name="value"></param>
  244. /// <returns></returns>
  245. Task ListSetByIndexAsync<T>(string key, int index, T value);
  246. /// <summary>
  247. /// 留下start到stop之间的数据。负数代表从右侧寻找 -1为右侧第一位
  248. /// </summary>
  249. /// <param name="key"></param>
  250. /// <param name="start"></param>
  251. /// <param name="stop"></param>
  252. /// <returns></returns>
  253. Task ListTrimAsync(string key, long start, long stop);
  254. /// <summary>
  255. /// 获取指定index的值,负数代表从右侧寻找 -1为右侧第一位
  256. /// </summary>
  257. /// <typeparam name="T"></typeparam>
  258. /// <param name="key"></param>
  259. /// <param name="index"></param>
  260. /// <returns></returns>
  261. Task<T> ListGetByIndexAsync<T>(string key, long index);
  262. #endregion
  263. #region Redis数据类型—Set
  264. /// <summary>
  265. /// 向指定集合中增加一个元素
  266. /// </summary>
  267. /// <typeparam name="T"></typeparam>
  268. /// <param name="key"></param>
  269. /// <param name="value"></param>
  270. /// <returns></returns>
  271. Task<bool> SetAddAsync<T>(string key, T value);
  272. ///// <summary>
  273. ///// 指定集合计算操作operation枚举,指定计算结果将存的目标destKey,指定需要参与计算的多个key
  274. ///// </summary>
  275. ///// <param name="operation"></param>
  276. ///// <param name="destKey"></param>
  277. ///// <param name="combineKeys"></param>
  278. ///// <returns></returns>
  279. //Task<long> SetCombineAndStoreAsync(SetOperation operation, string destKey, List<string> combineKeys);
  280. ///// <summary>
  281. ///// 指定集合计算操作operation枚举,指定需要参与计算的多个key
  282. ///// </summary>
  283. ///// <typeparam name="T"></typeparam>
  284. ///// <param name="operation"></param>
  285. ///// <param name="combineKeys"></param>
  286. ///// <returns></returns>
  287. //Task<List<T>> SetCombineAsync<T>(SetOperation operation, List<string> combineKeys);
  288. ///// <summary>
  289. ///// 指定值是否存在于指定集合中
  290. ///// </summary>
  291. ///// <typeparam name="T"></typeparam>
  292. ///// <param name="key"></param>
  293. ///// <param name="value"></param>
  294. ///// <returns></returns>
  295. //Task<bool> SetContainsAsync<T>(string key, T value);
  296. ///// <summary>
  297. ///// 获取指定集合中元素个数
  298. ///// </summary>
  299. ///// <param name="key"></param>
  300. ///// <returns></returns>
  301. //Task<long> SetLengthAsync(string key);
  302. ///// <summary>
  303. ///// 获取指定集合中的所有元素
  304. ///// </summary>
  305. ///// <typeparam name="T"></typeparam>
  306. ///// <param name="key"></param>
  307. ///// <param name="value"></param>
  308. ///// <returns></returns>
  309. //Task<List<T>> SetMembersAsync<T>(string key, T value);
  310. ///// <summary>
  311. ///// 从sourceKey移除指定value到目标distKey集合当中
  312. ///// 如果sourceKey存在指定value则返回true,否则不做任何操作返回false
  313. ///// </summary>
  314. ///// <typeparam name="T"></typeparam>
  315. ///// <param name="sourcekey"></param>
  316. ///// <param name="distKey"></param>
  317. ///// <param name="value"></param>
  318. ///// <returns></returns>
  319. //Task<bool> SetMoveAsync<T>(string sourcekey, string distKey, T value);
  320. ///// <summary>
  321. ///// 从指定集合当中随机取出一个元素
  322. ///// </summary>
  323. ///// <typeparam name="T"></typeparam>
  324. ///// <param name="key"></param>
  325. ///// <returns></returns>
  326. //Task<T> SetRandomMemberAsync<T>(string key);
  327. ///// <summary>
  328. ///// 从指定集合随机弹出(删除并获取)一个元素
  329. ///// </summary>
  330. ///// <typeparam name="T"></typeparam>
  331. ///// <param name="key"></param>
  332. ///// <returns></returns>
  333. //Task<T> SetPopAsync<T>(string key);
  334. ///// <summary>
  335. ///// 从集合中随机弹出(删除并获取)多个元素
  336. ///// </summary>
  337. ///// <typeparam name="T"></typeparam>
  338. ///// <param name="key"></param>
  339. ///// <returns></returns>
  340. //Task<List<T>> SetRandomMembersAsync<T>(string key);
  341. ///// <summary>
  342. ///// 从集合中移除指定元素
  343. ///// </summary>
  344. ///// <typeparam name="T"></typeparam>
  345. ///// <param name="key"></param>
  346. ///// <param name="value"></param>
  347. ///// <returns></returns>
  348. //Task<bool> SetRemoveAsync<T>(string key, T value);
  349. ///// <summary>
  350. ///// 从集合中批量移除元素
  351. ///// </summary>
  352. ///// <typeparam name="T"></typeparam>
  353. ///// <param name="key"></param>
  354. ///// <param name="values"></param>
  355. ///// <returns></returns>
  356. //Task<long> SetMultiRemoveAsync<T>(string key, List<T> values);
  357. #endregion
  358. #region Redis数据类型—SortSet
  359. #endregion
  360. #region Redis Key操作
  361. /// <summary>
  362. /// 删除指定key
  363. /// </summary>
  364. /// <param name="key"></param>
  365. /// <returns></returns>
  366. Task<bool> KeyDeleteAsync(string key);
  367. /// <summary>
  368. /// 设置key过期时间具体DateTime
  369. /// </summary>
  370. /// <param name="key"></param>
  371. /// <param name="expireAt"></param>
  372. /// <returns></returns>
  373. //Task<bool> KeyExpireAtAsync(string key, DateTime expireAt);
  374. /// <summary>
  375. /// 设置key在将来的timeout后过期(TimeSpan)
  376. /// </summary>
  377. /// <param name="key"></param>
  378. /// <param name="timeout"></param>
  379. /// <returns></returns>
  380. Task<bool> KeyExpireInAsync(string key, TimeSpan timeout);
  381. /// <summary>
  382. /// key重命名
  383. /// </summary>
  384. /// <param name="key"></param>
  385. /// <param name="newKey"></param>
  386. /// <returns></returns>
  387. Task<bool> KeyRenameAsync(string key, string newKey);
  388. /// <summary>
  389. /// 判断key是否已存在
  390. /// </summary>
  391. /// <param name="key"></param>
  392. /// <returns></returns>
  393. Task<bool> KeyExistsAsync(string key);
  394. #endregion
  395. #region Redis Transcation
  396. /// <summary>
  397. /// 在事务中执行一系列redis命令。注意:在委托中的一系列命令的所有 值 都需要进行字节数组序列化
  398. /// </summary>
  399. /// <param name="ranOperations"></param>
  400. /// <returns></returns>
  401. //Task<bool> DoInTranscationAsync(Action<ITransaction> ranOperations);
  402. #endregion
  403. }
  404. }