cfg_app_version.go
5.5 KB
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type CfgAppVersion struct {
Id int `orm:"column(id);auto"`
DeviceType int8 `orm:"column(device_type);null" description:"设备类型 (0 ios 1android)"`
VersionName string `orm:"column(version_name);size(255)" description:"版本名"`
VersionNo int `orm:"column(version_no)" description:"版本号"`
VersionState int8 `orm:"column(version_state)" description:"版本状态(0正常 1危险)"`
Title string `orm:"column(title);size(255)" description:"版本标题"`
Content string `orm:"column(content);size(500)" description:"更新的内容"`
DownloadPage string `orm:"column(download_page);size(255);null" description:"下载页"`
DownloadFile string `orm:"column(download_file);size(255)" description:"文件下载页"`
CreateTime time.Time `orm:"column(create_time);type(timestamp);null;auto_now"`
Enabled int8 `orm:"column(enabled);null" description:"是否有效"`
AdminId int `orm:"column(admin_id)" description:"操作人员"`
UpdateTime time.Time `orm:"column(update_time);type(timestamp);auto_now_add" description:"更新时间"`
Channel string `orm:"column(channel);size(255)" description:"当前渠道 0_AppStore、1_fir平台、2_华为、3_小米、4_魅族、5_oppo、6_vivo、7_360、8_百度、9_应用宝、10_其他(使用应用宝地址)"`
Type int8 `orm:"column(type);null" description:"0为手机 1为平板 终端类型"`
}
func (t *CfgAppVersion) TableName() string {
return "cfg_app_version"
}
func init() {
orm.RegisterModel(new(CfgAppVersion))
}
// AddCfgAppVersion insert a new CfgAppVersion into database and returns
// last inserted Id on success.
func AddCfgAppVersion(m *CfgAppVersion) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetCfgAppVersionById retrieves CfgAppVersion by Id. Returns error if
// Id doesn't exist
func GetCfgAppVersionById(id int) (v *CfgAppVersion, err error) {
o := orm.NewOrm()
v = &CfgAppVersion{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllCfgAppVersion retrieves all CfgAppVersion matches certain condition. Returns empty list if
// no records exist
func GetAllCfgAppVersion(query map[string]string, fields []string, sortby []string, order []string,
offset int64, limit int64) (ml []interface{}, err error) {
o := orm.NewOrm()
qs := o.QueryTable(new(CfgAppVersion))
// query k=v
for k, v := range query {
// rewrite dot-notation to Object__Attribute
k = strings.Replace(k, ".", "__", -1)
if strings.Contains(k, "isnull") {
qs = qs.Filter(k, (v == "true" || v == "1"))
} else {
qs = qs.Filter(k, v)
}
}
// order by:
var sortFields []string
if len(sortby) != 0 {
if len(sortby) == len(order) {
// 1) for each sort field, there is an associated order
for i, v := range sortby {
orderby := ""
if order[i] == "desc" {
orderby = "-" + v
} else if order[i] == "asc" {
orderby = v
} else {
return nil, errors.New("Error: Invalid order. Must be either [asc|desc]")
}
sortFields = append(sortFields, orderby)
}
qs = qs.OrderBy(sortFields...)
} else if len(sortby) != len(order) && len(order) == 1 {
// 2) there is exactly one order, all the sorted fields will be sorted by this order
for _, v := range sortby {
orderby := ""
if order[0] == "desc" {
orderby = "-" + v
} else if order[0] == "asc" {
orderby = v
} else {
return nil, errors.New("Error: Invalid order. Must be either [asc|desc]")
}
sortFields = append(sortFields, orderby)
}
} else if len(sortby) != len(order) && len(order) != 1 {
return nil, errors.New("Error: 'sortby', 'order' sizes mismatch or 'order' size is not 1")
}
} else {
if len(order) != 0 {
return nil, errors.New("Error: unused 'order' fields")
}
}
var l []CfgAppVersion
qs = qs.OrderBy(sortFields...)
if _, err = qs.Limit(limit, offset).All(&l, fields...); err == nil {
if len(fields) == 0 {
for _, v := range l {
ml = append(ml, v)
}
} else {
// trim unused fields
for _, v := range l {
m := make(map[string]interface{})
val := reflect.ValueOf(v)
for _, fname := range fields {
m[fname] = val.FieldByName(fname).Interface()
}
ml = append(ml, m)
}
}
return ml, nil
}
return nil, err
}
// UpdateCfgAppVersion updates CfgAppVersion by Id and returns error if
// the record to be updated doesn't exist
func UpdateCfgAppVersionById(m *CfgAppVersion) (err error) {
o := orm.NewOrm()
v := CfgAppVersion{Id: m.Id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Update(m); err == nil {
fmt.Println("Number of records updated in database:", num)
}
}
return
}
// DeleteCfgAppVersion deletes CfgAppVersion by Id and returns error if
// the record to be deleted doesn't exist
func DeleteCfgAppVersion(id int) (err error) {
o := orm.NewOrm()
v := CfgAppVersion{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&CfgAppVersion{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
func GetCfgAppVersion(versionNo,channel int)(v *CfgAppVersion, err error) {
o := orm.NewOrm()
sql :=`select * from cfg_app_version where version_no =? and channel =? and enabled=1`
if err = o.Raw(sql,versionNo,channel).QueryRow(&v); err == nil {
return v, nil
}
return nil, err
}