57 lines
2.2 KiB
Go
57 lines
2.2 KiB
Go
|
|
package models
|
|||
|
|
|
|||
|
|
import (
|
|||
|
|
"time"
|
|||
|
|
|
|||
|
|
"gorm.io/datatypes"
|
|||
|
|
)
|
|||
|
|
|
|||
|
|
// SensorDataType 定义了 SensorData 记录中 Data 字段的整体类型
|
|||
|
|
type SensorDataType string
|
|||
|
|
|
|||
|
|
const (
|
|||
|
|
SensorDataTypeSignalMetrics SensorDataType = "signal_metrics" // 信号强度
|
|||
|
|
SensorDataTypeBatteryLevel SensorDataType = "battery_level" // 电池电量
|
|||
|
|
)
|
|||
|
|
|
|||
|
|
// SignalMetrics 存储信号强度数据
|
|||
|
|
type SignalMetrics struct {
|
|||
|
|
RSSI int `json:"rssi"` // 绝对信号强度(dBm),受距离、障碍物影响
|
|||
|
|
SNR float64 `json:"snr"` // 信号与噪声的相对比率(dB),由 RSSI 减去噪声地板(Noise Floor)
|
|||
|
|
Sensitivity int `json:"sensitivity"` // 网关的最低检测阈值(dBm)
|
|||
|
|
Margin int `json:"margin"` // SNR 相对于接收器灵敏度的余量, Margin = SNR - Sensitivity
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// BatteryLevel 存储电池电量数据
|
|||
|
|
type BatteryLevel struct {
|
|||
|
|
BatteryLevel float32 `json:"battery_level"` // 电量剩余百分比
|
|||
|
|
BatteryLevelUnavailable bool `json:"battery_level_unavailable"` // 电量数据不可用
|
|||
|
|
ExternalPower bool `json:"external_power"` // 是否使用外部电源
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// SensorData 存储所有类型的传感器数据,对应数据库中的 'sensor_data' 表。
|
|||
|
|
type SensorData struct {
|
|||
|
|
// Time 是数据记录的时间戳,作为复合主键的一部分。
|
|||
|
|
// GORM 会将其映射到 'time' TIMESTAMPTZ 列。
|
|||
|
|
Time time.Time `gorm:"primaryKey" json:"time"`
|
|||
|
|
|
|||
|
|
// DeviceID 是传感器的唯一标识符,作为复合主键的另一部分。
|
|||
|
|
// GORM 会将其映射到 'device_id' VARCHAR(50) 列。
|
|||
|
|
DeviceID uint `gorm:"primaryKey" json:"device_id"`
|
|||
|
|
|
|||
|
|
// RegionalControllerID 是上报此数据的区域主控的ID。
|
|||
|
|
// 我们为其添加了数据库索引以优化按区域查询的性能。
|
|||
|
|
RegionalControllerID uint `json:"regional_controller_id"`
|
|||
|
|
|
|||
|
|
// SensorDataType 是传感数据的类型
|
|||
|
|
SensorDataType SensorDataType `gorm:"not null;index" json:"sensor_data_type"`
|
|||
|
|
|
|||
|
|
// Data 存储一个或多个传感器读数,格式为 JSON。
|
|||
|
|
// GORM 会使用 'jsonb' 类型来创建此列。
|
|||
|
|
Data datatypes.JSON `gorm:"type:jsonb" json:"data"`
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
func (SensorData) TableName() string {
|
|||
|
|
return "sensor_data"
|
|||
|
|
}
|