|
@@ -1,7 +1,6 @@
|
|
|
package dao
|
|
|
|
|
|
import (
|
|
|
- "fmt"
|
|
|
"time"
|
|
|
)
|
|
|
|
|
@@ -33,41 +32,33 @@ func (c *GatewayRelation) Get() error {
|
|
|
}
|
|
|
|
|
|
// 2022-12-08 dsx 查出所有数据更新进去
|
|
|
-func (c *GatewayRelation) Update(gatewayId int64) error {
|
|
|
+func (c *GatewayRelation) Update() error {
|
|
|
+ gatewayId := c.ID
|
|
|
relation := GatewayRelation{}
|
|
|
sql := `SELECT * from (
|
|
|
- (SELECT count(1) camera_count from device_camera where is_deleted=0 and gateway_id in (48)) as camera_count,
|
|
|
- (SELECT count(1) light_control_count from device_light_control where is_deleted=0 and gateway_id in (48)) as light_control_count,
|
|
|
- (SELECT count(1) info_board_count from device_info_board where is_deleted=0 and gateway_id in (48)) as info_board_count,
|
|
|
- (SELECT count(1) opto_sensor_count from device_opto_sensor where is_deleted=0 and gateway_id in (48)) as opto_sensor_count,
|
|
|
- (SELECT count(1) zigbee_count from device_zigbee where is_deleted=0 and gateway_id in (48)) as zigbee_count,
|
|
|
- (SELECT count(1) alarm_terminal_count from device_a_key_alarm_terminal where is_deleted=0 and gateway_id in (48)) as alarm_terminal_count,
|
|
|
- (SELECT count(1) capture_unit_count from device_capture_unit where is_deleted=0 and gateway_id in (48)) as capture_unit_count,
|
|
|
- (SELECT count(1) ip_broadcast_count from device_ip_broadcast where is_deleted=0 and gateway_id in (48)) as ip_broadcast_count,
|
|
|
- (SELECT count(1) curve_sensor_count from device_curve_sensor where is_deleted=0 and gateway_id in (48)) as curve_sensor_count
|
|
|
+ (SELECT count(1) camera_count from device_camera where is_deleted=0 and gateway_id in (?)) as camera_count,
|
|
|
+ (SELECT count(1) light_control_count from device_light_control where is_deleted=0 and gateway_id in (?)) as light_control_count,
|
|
|
+ (SELECT count(1) info_board_count from device_info_board where is_deleted=0 and gateway_id in (?)) as info_board_count,
|
|
|
+ (SELECT count(1) opto_sensor_count from device_opto_sensor where is_deleted=0 and gateway_id in (?)) as opto_sensor_count,
|
|
|
+ (SELECT count(1) zigbee_count from device_zigbee where is_deleted=0 and gateway_id in (?)) as zigbee_count,
|
|
|
+ (SELECT count(1) alarm_terminal_count from device_a_key_alarm_terminal where is_deleted=0 and gateway_id in (?)) as alarm_terminal_count,
|
|
|
+ (SELECT count(1) capture_unit_count from device_capture_unit where is_deleted=0 and gateway_id in (?)) as capture_unit_count,
|
|
|
+ (SELECT count(1) ip_broadcast_count from device_ip_broadcast where is_deleted=0 and gateway_id in (?)) as ip_broadcast_count,
|
|
|
+ (SELECT count(1) curve_sensor_count from device_curve_sensor where is_deleted=0 and gateway_id in (?)) as curve_sensor_count
|
|
|
) limit 1`
|
|
|
- //fmt.Printf("gatewayId = %v", gatewayId)
|
|
|
- //sql = strings.ReplaceAll(sql, "@id", string(gatewayId))
|
|
|
- //fmt.Printf("sql = %v", sql)
|
|
|
- //Db.Model(&c).Debug().Exec(sql, gatewayId, gatewayId, gatewayId, gatewayId, gatewayId, gatewayId, gatewayId, gatewayId, gatewayId).Scan(&relation)
|
|
|
- Db.Debug().Model(&c).Exec(sql).Scan(&relation)
|
|
|
- fmt.Printf("relation1 = %v", relation)
|
|
|
- return nil
|
|
|
- //relation.Total = relation.CameraCount + relation.LightControlCount + relation.InfoBoardCount +
|
|
|
- // relation.OptoSensorCount + relation.ZigbeeCount + relation.AlarmTerminalCount +
|
|
|
- // relation.CaptureUnitCount + relation.IpBroadcastCount + relation.CurveSensorCount
|
|
|
- //fmt.Printf("relation2 = %v", relation)
|
|
|
- ////return nil
|
|
|
- //var count int64
|
|
|
- //_ = Db.Debug().Model(&c).Where(" id = ? ", gatewayId).Count(&count)
|
|
|
- //fmt.Printf("count = %v", count)
|
|
|
- //if count > 0 {
|
|
|
- // relation.UpdateTime = time.Now()
|
|
|
- // return Db.Debug().Model(&c).Where(" id = ? ", gatewayId).Updates(&relation).Error
|
|
|
- //} else {
|
|
|
- // relation.ID = int(gatewayId)
|
|
|
- // relation.UpdateTime = time.Now()
|
|
|
- // relation.CreateTime = time.Now()
|
|
|
- // return Db.Debug().Model(&c).Create(&relation).Error
|
|
|
- //}
|
|
|
+ Db.Debug().Model(&c).Raw(sql, gatewayId, gatewayId, gatewayId, gatewayId, gatewayId, gatewayId, gatewayId, gatewayId, gatewayId).Scan(&relation)
|
|
|
+ relation.Total = relation.CameraCount + relation.LightControlCount + relation.InfoBoardCount +
|
|
|
+ relation.OptoSensorCount + relation.ZigbeeCount + relation.AlarmTerminalCount +
|
|
|
+ relation.CaptureUnitCount + relation.IpBroadcastCount + relation.CurveSensorCount
|
|
|
+ var count int64
|
|
|
+ _ = Db.Debug().Model(&c).Where(" id = ? ", gatewayId).Count(&count)
|
|
|
+ if count > 0 {
|
|
|
+ relation.UpdateTime = time.Now()
|
|
|
+ return Db.Debug().Model(&c).Where(" id = ? ", gatewayId).Updates(&relation).Error
|
|
|
+ } else {
|
|
|
+ relation.ID = int(gatewayId)
|
|
|
+ relation.UpdateTime = time.Now()
|
|
|
+ relation.CreateTime = time.Now()
|
|
|
+ return Db.Debug().Model(&c).Create(&relation).Error
|
|
|
+ }
|
|
|
}
|