trade.go 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. package tables
  2. import (
  3. "Wine-Server/utils"
  4. "database/sql"
  5. )
  6. type TradeTable struct {
  7. Id string
  8. Trade string
  9. Device string
  10. Time utils.TimeType
  11. Payer string
  12. Wine uint16
  13. Price uint16
  14. Weight uint16
  15. Cash uint32
  16. Manager string
  17. }
  18. func CreateTradeTable() error {
  19. SQL := "CREATE TABLE IF NOT EXISTS `trade`(" +
  20. "`id` VARCHAR(32) PRIMARY KEY NOT NULL," +
  21. "`trade` VARCHAR(64) NOT NULL," +
  22. "`device` VARCHAR(32) NOT NULL," +
  23. "`time` DATETIME DEFAULT CURRENT_TIMESTAMP," +
  24. "`payer` VARCHAR(64) NOT NULL," +
  25. "`wine` SMALLINT UNSIGNED NOT NULL," +
  26. "`price` SMALLINT UNSIGNED NOT NULL," +
  27. "`weight` SMALLINT UNSIGNED NOT NULL," +
  28. "`cash` INT UNSIGNED NOT NULL," +
  29. "`manager` VARCHAR(16));"
  30. _, err := utils.Mysql.Exec(SQL)
  31. return err
  32. }
  33. func (row *TradeTable) Insert() error {
  34. SQL := "INSERT INTO `trade`(`id`,`trade`,`device`,`payer`,`wine`,`price`,`weight`,`cash`,`manager`) VALUES(?,?,?,?,?,?,?,?,?);"
  35. pre, err := utils.Mysql.Prepare(SQL)
  36. if err != nil {
  37. return err
  38. }
  39. _, err = pre.Exec(row.Id, row.Trade, row.Device, row.Payer, row.Wine, row.Price, row.Weight, row.Cash, row.Manager)
  40. return err
  41. }
  42. func (row *TradeTable) Delete() error {
  43. pre, err := utils.Mysql.Prepare("DELETE FROM `trade` WHERE `id`=?;")
  44. if err != nil {
  45. return err
  46. }
  47. _, err = pre.Exec(row.Id)
  48. return err
  49. }
  50. func (row *TradeTable) Update(args utils.JsonType) error {
  51. keys, values := utils.UnZip(args)
  52. SQL := utils.Format("UPDATE `trade` SET %s WHERE `id`='%s';", utils.SqlFields(keys), row.Id)
  53. pre, err := utils.Mysql.Prepare(SQL)
  54. if err != nil {
  55. return err
  56. }
  57. _, err = pre.Exec(values...)
  58. return err
  59. }
  60. func (row *TradeTable) UpdateSelf() error {
  61. SQL := "UPDATE `trade` SET `trade`=?,`device`=?,`time`=?,`payer`=?,`wine`=?`price`=?,`weight`=?,`cash`=?,`manager`=? WHERE `id`=?;"
  62. pre, err := utils.Mysql.Prepare(SQL)
  63. if err != nil {
  64. return err
  65. }
  66. _, err = pre.Exec(row.Trade, row.Device, row.Time, row.Payer, row.Wine, row.Price, row.Weight, row.Cash, row.Manager, row.Id)
  67. return err
  68. }
  69. func (row *TradeTable) Get() error {
  70. SQL := "SELECT `trade`,`device`,`time`,`payer`,`wine`,`price`,`weight`,`cash`,`manager` FROM `trade` WHERE `id`=?;"
  71. pre, err := utils.Mysql.Prepare(SQL)
  72. if err != nil {
  73. return err
  74. }
  75. err = pre.QueryRow(row.Id).Scan(
  76. &row.Trade, &row.Device, &row.Time, &row.Payer,
  77. &row.Wine, &row.Price, &row.Weight, &row.Cash, &row.Manager,
  78. )
  79. return err
  80. }
  81. func TradeQuery(cond, uid string, limit, page int) (int, []utils.JsonType, error) {
  82. like := utils.Format("%%%s%%", cond)
  83. SQL := "SELECT COUNT(t.`id`) FROM `trade` AS t LEFT JOIN `wine` AS w ON t.`wine`=w.`id` WHERE t.`payer`=? AND (t.`id` LIKE ? OR w.`name` LIKE ?);"
  84. pre, err := utils.Mysql.Prepare(SQL)
  85. if err != nil {
  86. return 0, nil, err
  87. }
  88. total := 0
  89. err = pre.QueryRow(uid, like, like).Scan(&total)
  90. if err != nil {
  91. return 0, nil, err
  92. }
  93. if total == 0 {
  94. return 0, []utils.JsonType{}, nil
  95. }
  96. SQL = "SELECT t.`id`,t.`device`,t.`time`,w.`name`,t.`price`,t.`weight`,t.`cash`,r.`cash`,r.`reason` " +
  97. "FROM `trade` AS t LEFT JOIN `wine` AS w ON t.`wine`=w.`id` LEFT JOIN `refund` AS r ON t.`id`=r.`tid` " +
  98. "WHERE t.`payer`=? AND (t.`id` LIKE ? OR w.`name` LIKE ?) ORDER BY t.`time` DESC LIMIT ? OFFSET ?;"
  99. pre, err = utils.Mysql.Prepare(SQL)
  100. if err != nil {
  101. return 0, nil, err
  102. }
  103. var rows *sql.Rows
  104. rows, err = pre.Query(uid, like, like, limit, (page-1)*limit)
  105. if err != nil {
  106. return 0, nil, err
  107. }
  108. res := make([]utils.JsonType, 0)
  109. for rows.Next() {
  110. var one TradeTable
  111. refund := 0
  112. wineName, reason := "", ""
  113. _ = rows.Scan(&one.Id, &one.Device, &one.Time, &wineName, &one.Price, &one.Weight, &one.Cash, &refund, &reason)
  114. res = append(res, utils.JsonType{
  115. "id": one.Id, "device": one.Device, "time": one.Time, "wine": wineName, "price": one.Price,
  116. "weight": one.Weight, "cash": one.Cash, "refund": refund, "reason": reason,
  117. })
  118. }
  119. _ = rows.Close()
  120. return total, res, nil
  121. }