qixiaoning
2025-08-21 e38654fe9eff4562da4f18f8f018aed7879d493c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
package manage
 
import (
    "fmt"
    "strconv"
    "vamicro/iotData-service/model"
    "vamicro/iotData-service/serializer"
)
 
type ListDeviceService struct {
    BatteryStart string `form:"batteryStart" json:"batteryStart"` //电量左区间
    BatteryEnd   string `form:"batteryEnd" json:"batteryEnd"`     //电量👉区间
    SN           string `form:"sn" json:"sn"`                     //设备编码
    Page         int    `form:"page" json:"page"`                 //页码
    PageSize     int    `form:"pageSize" json:"pageSize"`         //分页大小
}
 
func (service *ListDeviceService) List() serializer.Response {
    devices := []model.Device{}
 
    var total int64
    code := 200
    db := model.DB.Table("devices")
    if service.SN != "" {
        obj := model.DrawZone{}
        err := obj.FindByName(service.SN)
        if err == nil {
            return serializer.Response{
                Status: 200,
                Msg:    "zone",
                Data:   obj,
            }
        } else {
            fmt.Println("find zone error:::", err)
        }
        db = db.Where("sn like ?", "%"+service.SN+"%")
    }
    start, _ := strconv.Atoi(service.BatteryStart)
    end, _ := strconv.Atoi(service.BatteryEnd)
 
    if service.BatteryStart != "" && service.BatteryEnd != "" {
        db = db.Where("battery BETWEEN ? AND ?", start, end)
    } else if service.BatteryStart != "" {
        db = db.Where("battery >= ?", start)
    } else if service.BatteryEnd != "" {
        db = db.Where("battery <= ?", end)
    }
 
    if err := db.Count(&total).Error; err != nil {
        code = 30001
        return serializer.Response{
            Status: code,
            Msg:    "数据库错误 count",
            Error:  err.Error(),
        }
    }
    if service.PageSize == 0 && service.Page == 0 {
        if err := db.Find(&devices).Error; err != nil {
            code = 30001
            return serializer.Response{
                Status: code,
                Msg:    "数据库错误",
                Error:  err.Error(),
            }
        }
    } else {
        if err := db.Limit(service.PageSize).Offset((service.Page - 1) * service.PageSize).Find(&devices).Error; err != nil {
            code = 30001
            return serializer.Response{
                Status: code,
                Msg:    "数据库错误",
                Error:  err.Error(),
            }
        }
    }
    return serializer.BuildListResponse(serializer.BuildDevicesRsp(devices), uint(total))
}