Utils.cs 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using MySystem.PxcModels;
  5. namespace MySystem
  6. {
  7. public class Utils
  8. {
  9. public readonly static Utils Instance = new Utils();
  10. private Utils()
  11. { }
  12. /// <summary>
  13. /// 操作收支明细
  14. /// </summary>
  15. /// <param name="UserId"></param>
  16. /// <param name="Money"></param>
  17. /// <param name="ChangeType"></param>
  18. public void OpAccount(int UserId, decimal Money, int ChangeType, bool IsTotal = true)
  19. {
  20. WebCMSEntities db = new WebCMSEntities();
  21. UserAccount account = db.UserAccount.FirstOrDefault(m => m.Id == UserId);
  22. if (account == null)
  23. {
  24. account = db.UserAccount.Add(new UserAccount()
  25. {
  26. Id = UserId,
  27. UserId = UserId,
  28. }).Entity;
  29. db.SaveChanges();
  30. }
  31. decimal BeforeTotalAmount = account.TotalAmount; //变更前总金额
  32. decimal BeforeFreezeAmount = account.FreezeAmount; //变更前冻结金额
  33. decimal BeforeBalanceAmount = account.BalanceAmount; //变更前余额
  34. account.BalanceAmount += Money;
  35. if(IsTotal)
  36. {
  37. account.TotalAmount += Money;
  38. }
  39. decimal AfterTotalAmount = account.TotalAmount; //变更后总金额
  40. decimal AfterFreezeAmount = account.FreezeAmount; //变更后冻结金额
  41. decimal AfterBalanceAmount = account.BalanceAmount; //变更后余额
  42. UserAccountRecord userAccountRecord = db.UserAccountRecord.Add(new UserAccountRecord()
  43. {
  44. CreateDate = DateTime.Now,
  45. UpdateDate = DateTime.Now,
  46. UserId = UserId, //创客
  47. ChangeType = ChangeType, //变动类型
  48. ChangeAmount = Money, //变更金额
  49. BeforeTotalAmount = BeforeTotalAmount, //变更前总金额
  50. AfterTotalAmount = AfterTotalAmount, //变更后总金额
  51. BeforeFreezeAmount = BeforeFreezeAmount, //变更前冻结金额
  52. AfterFreezeAmount = AfterFreezeAmount, //变更后冻结金额
  53. BeforeBalanceAmount = BeforeBalanceAmount, //变更前余额
  54. AfterBalanceAmount = AfterBalanceAmount, //变更后余额
  55. }).Entity;
  56. db.SaveChanges();
  57. db.Dispose();
  58. }
  59. public void ToChargeAmount(int UserId, decimal Money)
  60. {
  61. WebCMSEntities db = new WebCMSEntities();
  62. UserAccount account = db.UserAccount.FirstOrDefault(m => m.Id == UserId);
  63. if (account == null)
  64. {
  65. account = db.UserAccount.Add(new UserAccount()
  66. {
  67. Id = UserId,
  68. UserId = UserId,
  69. }).Entity;
  70. db.SaveChanges();
  71. }
  72. account.ToChargeAmount += Money;
  73. db.SaveChanges();
  74. db.Dispose();
  75. }
  76. }
  77. }