MeetingOrderRepository.cs 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Threading.Tasks;
  4. using Dapper;
  5. using Datory;
  6. using GxPress.Common.AppOptions;
  7. using GxPress.Common.Tools;
  8. using GxPress.Entity.WorkMeeting;
  9. using GxPress.Repository.Interface.WorkMeeting;
  10. using GxPress.Result.Meeting;
  11. using Microsoft.Extensions.Caching.Distributed;
  12. using Microsoft.Extensions.Options;
  13. using SqlKata;
  14. namespace GxPress.Repository.Implement.WorkMeeting
  15. {
  16. public class MeetingOrderRepository : IMeetingOrderRepository
  17. {
  18. private readonly Repository<MeetingOrder> _repository;
  19. public MeetingOrderRepository(IOptionsMonitor<DatabaseOptions> dbOptionsAccessor, IDistributedCache cache)
  20. {
  21. var databaseType = StringUtils.ToEnum<DatabaseType>(dbOptionsAccessor.CurrentValue.DatabaseType, DatabaseType.MySql);
  22. var database = new Database(databaseType, dbOptionsAccessor.CurrentValue.ConnectionString);
  23. _repository = new Repository<MeetingOrder>(database, cache);
  24. }
  25. public IDatabase Database => _repository.Database;
  26. public string TableName => _repository.TableName;
  27. public List<TableColumn> TableColumns => _repository.TableColumns;
  28. public async Task<int> InsertAsync(MeetingOrder item)
  29. {
  30. return await _repository.InsertAsync(item);
  31. }
  32. public async Task<IEnumerable<MeetingOrder>> GetListAsync(int roomId)
  33. {
  34. return await _repository.GetAllAsync(Q.Where(nameof(MeetingOrder.RoomId), roomId));
  35. }
  36. public async Task<IEnumerable<MeetingOrder>> GetListByMeetingIdAsync(int meetingId)
  37. {
  38. return await _repository.GetAllAsync(Q.Where(nameof(MeetingOrder.MeetingId), meetingId).OrderByDesc(nameof(MeetingOrder.Date)));
  39. }
  40. public async Task<IEnumerable<MeetingOrderResult>> GetListAsyncSinceNow(int roomId)
  41. {
  42. string sql = $@"SELECT
  43. a.*,c.Id as UserId,c.Name as UserName
  44. FROM
  45. tede_meeting_order a
  46. INNER JOIN
  47. tede_meeting b ON a.MeetingId = b.Id
  48. INNER JOIN
  49. tede_user c ON c.Id = b.UserId
  50. WHERE
  51. a.RoomId ={roomId} AND a.Date >= date_format(NOW() , '%Y%m%d')";
  52. var database = new Database(DatabaseType.MySql, ConfigHelper.GetValue("Database:ConnectionString"));
  53. var connection = database.GetConnection();
  54. return await connection.QueryAsync<MeetingOrderResult>(sql);
  55. }
  56. public async Task<bool> DeleteAsync(int orderId)
  57. {
  58. return await _repository.DeleteAsync(orderId);
  59. }
  60. public async Task DeleteByRoomIdAsync(int roomId)
  61. {
  62. await _repository.DeleteAsync(Q.Where(nameof(MeetingOrder.RoomId), roomId));
  63. }
  64. public async Task DeleteByMeetingIdAsync(int meetingId)
  65. {
  66. await _repository.DeleteAsync(Q.Where(nameof(MeetingOrder.MeetingId), meetingId));
  67. }
  68. public async Task<bool> DeleteAsync(Query query)
  69. {
  70. return await _repository.DeleteAsync(query) > 0;
  71. }
  72. }
  73. }