|
@@ -0,0 +1,295 @@
|
|
|
+package tables
|
|
|
+
|
|
|
+import (
|
|
|
+ "Wine-Server/utils"
|
|
|
+ "database/sql"
|
|
|
+)
|
|
|
+
|
|
|
+type ChangeTable struct {
|
|
|
+ Id uint32
|
|
|
+ Wid uint32
|
|
|
+ Device string
|
|
|
+ Manager string
|
|
|
+ Worker string
|
|
|
+ Code string
|
|
|
+ Deal bool
|
|
|
+ Publish utils.TimeType
|
|
|
+ Finish utils.TimeType
|
|
|
+ Old [4]WineWithIdRemain
|
|
|
+ New [4]WineWithIdRemain
|
|
|
+}
|
|
|
+
|
|
|
+func CreateChangeTable() error {
|
|
|
+ SQL := "CREATE TABLE IF NOT EXISTS `change`(" +
|
|
|
+ "`id` INT UNSIGNED AUTO_INCREMENT PRIMARY KEY NOT NULL," +
|
|
|
+ "`wid` INT UNSIGNED NOT NULL," +
|
|
|
+ "`device` VARCHAR(32) NOT NULL,`manager` VARCHAR(16) NOT NULL," +
|
|
|
+ "`worker` VARCHAR(16) NOT NULL,`code` VARCHAR(6) NOT NULL," +
|
|
|
+ "`deal` BOOL DEFAULT FALSE," +
|
|
|
+ "`publish` DATETIME DEFAULT CURRENT_TIMESTAMP," +
|
|
|
+ "`finish` DATETIME DEFAULT CURRENT_TIMESTAMP," +
|
|
|
+ "`wine1o` SMALLINT UNSIGNED DEFAULT 0," +
|
|
|
+ "`remain1o` SMALLINT UNSIGNED DEFAULT 0," +
|
|
|
+ "`wine2o` SMALLINT UNSIGNED DEFAULT 0," +
|
|
|
+ "`remain2o` SMALLINT UNSIGNED DEFAULT 0," +
|
|
|
+ "`wine3o` SMALLINT UNSIGNED DEFAULT 0," +
|
|
|
+ "`remain3o` SMALLINT UNSIGNED DEFAULT 0," +
|
|
|
+ "`wine4o` SMALLINT UNSIGNED DEFAULT 0," +
|
|
|
+ "`remain4o` SMALLINT UNSIGNED DEFAULT 0," +
|
|
|
+ "`wine1n` SMALLINT UNSIGNED DEFAULT 0," +
|
|
|
+ "`remain1n` SMALLINT UNSIGNED DEFAULT 0," +
|
|
|
+ "`wine2n` SMALLINT UNSIGNED DEFAULT 0," +
|
|
|
+ "`remain2n` SMALLINT UNSIGNED DEFAULT 0," +
|
|
|
+ "`wine3n` SMALLINT UNSIGNED DEFAULT 0," +
|
|
|
+ "`remain3n` SMALLINT UNSIGNED DEFAULT 0," +
|
|
|
+ "`wine4n` SMALLINT UNSIGNED DEFAULT 0," +
|
|
|
+ "`remain4n` SMALLINT UNSIGNED DEFAULT 0);"
|
|
|
+ _, err := utils.Mysql.Exec(SQL)
|
|
|
+ return err
|
|
|
+}
|
|
|
+
|
|
|
+func (row *ChangeTable) Insert() error {
|
|
|
+ SQL := "INSERT INTO `change` (``wid,`device`,`manager`,`worker`,`code`,`wine1o`,`remain1o`,`wine2o`,`remain2o`," +
|
|
|
+ "`wine3o`,`remain3o`,`wine4o`,`remain4o`,`wine1n`,`remain1n`,`wine2n`,`remain2n`,`wine3n`,`remain3n`," +
|
|
|
+ "`wine4n`,`remain4n`) VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?);"
|
|
|
+ pre, err := utils.Mysql.Prepare(SQL)
|
|
|
+ if err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
+ _, err = pre.Exec(
|
|
|
+ row.Wid, row.Device, row.Manager, row.Worker, row.Code,
|
|
|
+ row.Old[0].Id, row.Old[0].Remain, row.Old[1].Id, row.Old[1].Remain,
|
|
|
+ row.Old[2].Id, row.Old[2].Remain, row.Old[3].Id, row.Old[3].Remain,
|
|
|
+ row.New[0].Id, row.New[0].Remain, row.New[1].Id, row.New[1].Remain,
|
|
|
+ row.New[2].Id, row.New[2].Remain, row.New[3].Id, row.New[3].Remain,
|
|
|
+ )
|
|
|
+ return err
|
|
|
+}
|
|
|
+
|
|
|
+func (row *ChangeTable) Delete() error {
|
|
|
+ _, err := utils.Mysql.Exec("DELETE FROM `change` WHERE `id`=?;", row.Id)
|
|
|
+ return err
|
|
|
+}
|
|
|
+
|
|
|
+func (row *ChangeTable) Update(args utils.JsonType) error {
|
|
|
+ keys, values := utils.UnZip(args)
|
|
|
+ SQL := utils.Format("UPDATE `change` SET %s WHERE `id`=%d;", utils.SqlFields(keys), row.Id)
|
|
|
+ pre, err := utils.Mysql.Prepare(SQL)
|
|
|
+ if err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
+ _, err = pre.Exec(values...)
|
|
|
+ return err
|
|
|
+}
|
|
|
+
|
|
|
+func (row *ChangeTable) UpdateSelf() error {
|
|
|
+ SQL := "UPDATE `change` SET `wid`=?,`device`=?,`manager`=?,`worker`=?,`code`=?,`deal`=?,`publish`=?,`finish`=?," +
|
|
|
+ "`wine1o`=?,`remain1o`=?,`wine2o`=?,`remain2o`=?,`wine3o`=?,`remain3o`=?,`wine4o`=?,`remain4o`=?," +
|
|
|
+ "`wine1n`=?,`remain1n`=?,`wine2n`=?,`remain2n`=?,`wine3n`=?,`remain3n`=?,`wine4n`=?,`remain4n`=? WHERE `id`=?;"
|
|
|
+ _, err := utils.Mysql.Exec(
|
|
|
+ SQL, row.Wid, row.Device, row.Manager, row.Worker,
|
|
|
+ row.Code, row.Deal, row.Publish, row.Finish,
|
|
|
+ row.Old[0].Id, row.Old[0].Remain, row.Old[1].Id, row.Old[1].Remain,
|
|
|
+ row.Old[2].Id, row.Old[2].Remain, row.Old[3].Id, row.Old[3].Remain,
|
|
|
+ row.New[0].Id, row.New[0].Remain, row.New[1].Id, row.New[1].Remain,
|
|
|
+ row.New[2].Id, row.New[2].Remain, row.New[3].Id, row.New[3].Remain, row.Id,
|
|
|
+ )
|
|
|
+ return err
|
|
|
+}
|
|
|
+
|
|
|
+func (row *ChangeTable) Get() error {
|
|
|
+ SQL := "SELECT `wid`,`device`,`manager`,`worker`,`code`,`deal`,`publish`,`finish`," +
|
|
|
+ "`wine1o`,`remain1o`,`wine2o`,`remain2o`,`wine3o`,`remain3o`,`wine4o`,`remain4o`," +
|
|
|
+ "`wine1n`,`remain1n`,`wine2n`,`remain2n`,`wine3n`,`remain3n`,`wine4n`,`remain4n` FROM `change` WHERE `id`=?;"
|
|
|
+ err := utils.Mysql.QueryRow(SQL, row.Id).Scan(
|
|
|
+ &row.Wid, &row.Device, &row.Manager, &row.Worker,
|
|
|
+ &row.Code, &row.Deal, &row.Publish, &row.Finish,
|
|
|
+ &row.Old[0].Id, &row.Old[0].Remain, &row.Old[1].Id, &row.Old[1].Remain,
|
|
|
+ &row.Old[2].Id, &row.Old[2].Remain, &row.Old[3].Id, &row.Old[3].Remain,
|
|
|
+ &row.New[0].Id, &row.New[0].Remain, &row.New[1].Id, &row.New[1].Remain,
|
|
|
+ &row.New[2].Id, &row.New[2].Remain, &row.New[3].Id, &row.New[3].Remain,
|
|
|
+ )
|
|
|
+ return err
|
|
|
+}
|
|
|
+
|
|
|
+type changeQueryRes struct {
|
|
|
+ Id uint32 `json:"id"`
|
|
|
+ Device struct {
|
|
|
+ Id string `json:"id"`
|
|
|
+ Addr string `json:"addr"`
|
|
|
+ } `json:"device"`
|
|
|
+ Code string `json:"code"`
|
|
|
+ Deal bool `json:"deal"`
|
|
|
+ Publish utils.TimeType `json:"publish"`
|
|
|
+ Finish utils.TimeType `json:"finish"`
|
|
|
+
|
|
|
+ Old [4]WineWithIdNameRemain `json:"old"`
|
|
|
+ New [4]WineWithIdNameRemain `json:"new"`
|
|
|
+}
|
|
|
+
|
|
|
+func ChangesQuery(manager, worker, cond string, deal, limit, page int) (int, []changeQueryRes, error) {
|
|
|
+ SQL, like := "none", utils.Format("%%%s%%", cond)
|
|
|
+ if deal == -1 {
|
|
|
+ SQL = utils.Format(
|
|
|
+ "SELECT COUNT(c.`id`) FROM `change` AS c LEFT JOIN `device` AS d ON c.`device`=d.`id`"+
|
|
|
+ "WHERE c.`manager`='%s' AND c.`worker`='%s' AND (d.`id` LIKE '%s' OR d.`addr` LIKE '%s')",
|
|
|
+ manager, worker, like, like,
|
|
|
+ )
|
|
|
+ } else {
|
|
|
+ SQL = utils.Format(
|
|
|
+ "SELECT COUNT(c.`id`) FROM `change` AS c LEFT JOIN `device` AS d ON c.`device`=d.`id`"+
|
|
|
+ "WHERE c.`deal`=%d AND c.`manager`='%s' AND c.`worker`='%s' AND (d.`id` LIKE '%s' OR d.`addr` LIKE '%s')",
|
|
|
+ deal, manager, worker, like, like,
|
|
|
+ )
|
|
|
+ }
|
|
|
+ total := 0
|
|
|
+ err := utils.Mysql.QueryRow(SQL).Scan(&total)
|
|
|
+ if err != nil {
|
|
|
+ return 0, nil, err
|
|
|
+ }
|
|
|
+ if total == 0 {
|
|
|
+ return 0, []changeQueryRes{}, err
|
|
|
+ }
|
|
|
+ if deal == -1 {
|
|
|
+ SQL = utils.Format(
|
|
|
+ "SELECT c.`id`,d.`id`,d.`addr`,c.`code`,c.`deal`,c.`publish`,c.`finish`,"+
|
|
|
+ "w1.`id`,w1.`name`,c.`remain1o`,w2.`id`,w2.`name`,c.`remain2o`,"+
|
|
|
+ "w3.`id`,w3.`name`,c.`remain3o`,w4.`id`,w4.`name`,c.`remain4o`,"+
|
|
|
+ "w5.`id`,w5.`name`,c.`remain1n`,w6.`id`,w6.`name`,c.`remain2n`,"+
|
|
|
+ "w7.`id`,w7.`name`,c.`remain3n`,w8.`id`,w8.`name`,c.`remain4n` "+
|
|
|
+ "FROM `change` AS c LEFT JOIN `device` AS d ON c.`device`=d.`id`"+
|
|
|
+ "INNER JOIN `wine` AS w1 ON w1.`id`=c.`wine1o` INNER JOIN `wine` AS w2 ON w2.`id`=c.`wine2o` "+
|
|
|
+ "INNER JOIN `wine` AS w3 ON w3.`id`=c.`wine3o` INNER JOIN `wine` AS w4 ON w4.`id`=c.`wine4o` "+
|
|
|
+ "INNER JOIN `wine` AS w5 ON w5.`id`=c.`wine1n` INNER JOIN `wine` AS w6 ON w6.`id`=c.`wine2n` "+
|
|
|
+ "INNER JOIN `wine` AS w7 ON w7.`id`=c.`wine3n` INNER JOIN `wine` AS w8 ON w8.`id`=c.`wine4n` "+
|
|
|
+ "WHERE c.`manager`='%s' AND c.`worker`='%s' AND (d.`id` LIKE '%s' OR d.`addr` LIKE '%s') "+
|
|
|
+ "LIMIT %d OFFSET %d;", manager, worker, like, like, limit, (page-1)*limit,
|
|
|
+ )
|
|
|
+ } else {
|
|
|
+ SQL = utils.Format(
|
|
|
+ "SELECT c.`id`,d.`id`,d.`addr`,c.`code`,c.`deal`,c.`publish`,c.`finish`,"+
|
|
|
+ "w1.`id`,w1.`name`,c.`remain1o`,w2.`id`,w2.`name`,c.`remain2o`,"+
|
|
|
+ "w3.`id`,w3.`name`,c.`remain3o`,w4.`id`,w4.`name`,c.`remain4o`,"+
|
|
|
+ "w5.`id`,w5.`name`,c.`remain1n`,w6.`id`,w6.`name`,c.`remain2n`,"+
|
|
|
+ "w7.`id`,w7.`name`,c.`remain3n`,w8.`id`,w8.`name`,c.`remain4n` "+
|
|
|
+ "FROM `change` AS c LEFT JOIN `device` AS d ON c.`device`=d.`id`"+
|
|
|
+ "INNER JOIN `wine` AS w1 ON w1.`id`=c.`wine1o` INNER JOIN `wine` AS w2 ON w2.`id`=c.`wine2o` "+
|
|
|
+ "INNER JOIN `wine` AS w3 ON w3.`id`=c.`wine3o` INNER JOIN `wine` AS w4 ON w4.`id`=c.`wine4o` "+
|
|
|
+ "INNER JOIN `wine` AS w5 ON w5.`id`=c.`wine1n` INNER JOIN `wine` AS w6 ON w6.`id`=c.`wine2n` "+
|
|
|
+ "INNER JOIN `wine` AS w7 ON w7.`id`=c.`wine3n` INNER JOIN `wine` AS w8 ON w8.`id`=c.`wine4n` "+
|
|
|
+ "WHERE c.`deal`=%d AND c.`manager`='%s' AND c.`worker`='%s' AND (d.`id` LIKE '%s' OR d.`addr` LIKE '%s') "+
|
|
|
+ "LIMIT %d OFFSET %d;", deal, manager, worker, like, like, limit, (page-1)*limit,
|
|
|
+ )
|
|
|
+ }
|
|
|
+ var rows *sql.Rows
|
|
|
+ res := make([]changeQueryRes, 0)
|
|
|
+ rows, err = utils.Mysql.Query(SQL)
|
|
|
+ if err != nil {
|
|
|
+ return 0, nil, err
|
|
|
+ }
|
|
|
+ for rows.Next() {
|
|
|
+ var one changeQueryRes
|
|
|
+ _ = rows.Scan(
|
|
|
+ &one.Id, &one.Device.Id, &one.Device.Addr, &one.Code, &one.Deal, &one.Publish, &one.Finish,
|
|
|
+ &one.Old[0].Id, &one.Old[0].Name, &one.Old[0].Remain,
|
|
|
+ &one.Old[1].Id, &one.Old[1].Name, &one.Old[1].Remain,
|
|
|
+ &one.Old[2].Id, &one.Old[2].Name, &one.Old[2].Remain,
|
|
|
+ &one.Old[3].Id, &one.Old[3].Name, &one.Old[3].Remain,
|
|
|
+ &one.New[0].Id, &one.New[0].Name, &one.New[0].Remain,
|
|
|
+ &one.New[1].Id, &one.New[1].Name, &one.New[1].Remain,
|
|
|
+ &one.New[2].Id, &one.New[2].Name, &one.New[2].Remain,
|
|
|
+ &one.New[3].Id, &one.New[3].Name, &one.New[3].Remain,
|
|
|
+ )
|
|
|
+ res = append(res, one)
|
|
|
+ }
|
|
|
+ _ = rows.Close()
|
|
|
+ return total, res, nil
|
|
|
+}
|
|
|
+
|
|
|
+func ChangeRankWorkers(start, end string) ([]idNameTotal, error) {
|
|
|
+ SQL := "SELECT w.`id` AS `person`,w.`name`,SUM(c.`id`) AS `count` FROM `change` AS c " +
|
|
|
+ "LEFT JOIN `worker` AS w ON c.`worker`=w.`id` WHERE c.`deal`=TRUE " +
|
|
|
+ "AND (c.`finish` BETWEEN TIMESTAMP(?) AND TIMESTAMP(?)) GROUP BY `person` ORDER BY `count` DESC;"
|
|
|
+ rows, err := utils.Mysql.Query(SQL, start, end)
|
|
|
+ if err != nil {
|
|
|
+ return nil, err
|
|
|
+ }
|
|
|
+ res := make([]idNameTotal, 0)
|
|
|
+ for rows.Next() {
|
|
|
+ var one idNameTotal
|
|
|
+ _ = rows.Scan(&one.Id, &one.Name, &one.Total)
|
|
|
+ res = append(res, one)
|
|
|
+ }
|
|
|
+ _ = rows.Close()
|
|
|
+ return res, nil
|
|
|
+}
|
|
|
+
|
|
|
+func ChangeRankWorkersForAdmin(manager, start, end string) ([]idNameTotal, error) {
|
|
|
+ SQL := "SELECT w.`id` AS `person`,w.`name`,SUM(c.`id`) AS `count` FROM `change` AS c " +
|
|
|
+ "LEFT JOIN `worker` AS w ON c.`worker`=w.`id` WHERE c.`deal`=TRUE AND c.`manager`=? " +
|
|
|
+ "AND (c.`finish` BETWEEN TIMESTAMP(?) AND TIMESTAMP(?)) GROUP BY `person` ORDER BY `count` DESC;"
|
|
|
+ rows, err := utils.Mysql.Query(SQL, manager, start, end)
|
|
|
+ if err != nil {
|
|
|
+ return nil, err
|
|
|
+ }
|
|
|
+ res := make([]idNameTotal, 0)
|
|
|
+ for rows.Next() {
|
|
|
+ var one idNameTotal
|
|
|
+ _ = rows.Scan(&one.Id, &one.Name, &one.Total)
|
|
|
+ res = append(res, one)
|
|
|
+ }
|
|
|
+ _ = rows.Close()
|
|
|
+ return res, nil
|
|
|
+}
|
|
|
+
|
|
|
+func ChangeQueryWorker(id string, kind uint8) ([]timeTotal, error) {
|
|
|
+ SQL := "none"
|
|
|
+ if kind == 0 {
|
|
|
+ SQL = "SELECT DATE_FORMAT(`time`,'%Y-%m') as `tt`,SUM(`id`) FROM `change` WHERE `deal`=TRUE AND `worker`=? GROUP BY `tt`;"
|
|
|
+ } else {
|
|
|
+ align, days := getAlignDays(kind)
|
|
|
+ SQL = utils.Format(
|
|
|
+ "SELECT DATE_FORMAT(`time`,'%s') as `tt`,SUM(`tt`) FROM `change` WHERE `deal`=TRUE AND `worker`=? AND (`time` BETWEEN "+
|
|
|
+ "DATE_SUB(CURRENT_TIMESTAMP,INTERVAL %d DAY) AND CURRENT_TIMESTAMP) GROUP BY `tt`;", align, days,
|
|
|
+ )
|
|
|
+ }
|
|
|
+ rows, err := utils.Mysql.Query(SQL, id)
|
|
|
+ if err != nil {
|
|
|
+ return nil, err
|
|
|
+ }
|
|
|
+ res := make([]timeTotal, 0)
|
|
|
+ for rows.Next() {
|
|
|
+ var one timeTotal
|
|
|
+ _ = rows.Scan(&one.Time, &one.Total)
|
|
|
+ res = append(res, one)
|
|
|
+ }
|
|
|
+ _ = rows.Close()
|
|
|
+ return res, nil
|
|
|
+}
|
|
|
+
|
|
|
+func ChangeQueryWorkerForAdmin(manager, id string, kind uint8) ([]timeTotal, error) {
|
|
|
+ SQL := "none"
|
|
|
+ if kind == 0 {
|
|
|
+ SQL = "SELECT DATE_FORMAT(`time`,'%Y-%m') as `tt`,SUM(`id`) FROM `change` " +
|
|
|
+ "WHERE `deal`=TRUE AND `manager`=? AND `worker`=? GROUP BY `tt`;"
|
|
|
+ } else {
|
|
|
+ align, days := getAlignDays(kind)
|
|
|
+ SQL = utils.Format(
|
|
|
+ "SELECT DATE_FORMAT(`time`,'%s') as `tt`,SUM(`tt`) FROM `change` WHERE `deal`=TRUE AND `manager`=? "+
|
|
|
+ "AND `worker`=? AND (`time` BETWEEN DATE_SUB(CURRENT_TIMESTAMP,INTERVAL %d DAY) AND CURRENT_TIMESTAMP) "+
|
|
|
+ "GROUP BY `tt`;", align, days,
|
|
|
+ )
|
|
|
+ }
|
|
|
+ rows, err := utils.Mysql.Query(SQL, manager, id)
|
|
|
+ if err != nil {
|
|
|
+ return nil, err
|
|
|
+ }
|
|
|
+ res := make([]timeTotal, 0)
|
|
|
+ for rows.Next() {
|
|
|
+ var one timeTotal
|
|
|
+ _ = rows.Scan(&one.Time, &one.Total)
|
|
|
+ res = append(res, one)
|
|
|
+ }
|
|
|
+ _ = rows.Close()
|
|
|
+ return res, nil
|
|
|
+}
|