作者 yangfu

fix

要显示太多修改。

为保证性能只显示 40 of 40+ 个文件。

[dev]
#数据库相关
data_source = "root:123456@tcp(192.168.100.102:3306)/opportunity?loc=Local"
data_source = "root:123456@tcp(127.0.0.1:3306)/opportunity?loc=Local"
#data_source = "root:sutianxia2015@tcp(115.29.205.99:3306)/ability_display"
#data_source = "root:root@tcp(localhost:3306)/ability_display?loc=Local"
#redis相关配置
redis_add_port = "192.168.100.102:6379"
redis_add_port = "127.0.0.1:6379"
redis_auth = "123456"
#sms相关配置
... ...
... ... @@ -184,7 +184,7 @@ func CheckToken(ctx *context.Context) (result bool) {
} else {
if rsp.UserInfo != nil {
//设置附加数据
ctx.Request.Header.Add("uid", fmt.Sprintf("%v", rsp.UserInfo.Uuid))
ctx.Request.Header.Add("uid", fmt.Sprintf("%v", rsp.UserInfo.UserId))
}
}
return
... ...
... ... @@ -3,27 +3,23 @@ package controllers
import (
"fmt"
"log"
"opp/protocol"
"reflect"
"testing"
"time"
"gitlab.fjmaimaimai.com/mmm-go/gocomm/common"
"gitlab.fjmaimaimai.com/mmm-go/gocomm/pkg/mybeego"
)
func Test_GenMessage(t *testing.T) {
input := []struct {
Rsp interface{}
Error error
Exceprt *mybeego.Message
Exceprt *protocol.ResponseMessage
}{
{Rsp: "test", Error: fmt.Errorf("test"), Exceprt: mybeego.NewMessage(1)},
{Rsp: "test-A", Error: common.NewErrorWithMsg(100, "test-A"), Exceprt: mybeego.NewErrMessage(100, "test-A")},
{Rsp: "test", Error: fmt.Errorf("test"), Exceprt: protocol.NewErrWithMessage(1, fmt.Errorf("test")).ParseToMessage()},
{Rsp: "test-A", Error: protocol.NewErrWithMessage(100, fmt.Errorf("test-A")), Exceprt: protocol.NewErrWithMessage(100, fmt.Errorf("test-A")).ParseToMessage()},
}
for i := range input {
o := input[i]
out := DefaultController.GenMessage(o.Rsp, o.Error)
out := protocol.NewReturnResponse(o.Rsp, o.Error)
if !reflect.DeepEqual(out, o.Exceprt) {
log.Fatal("not equal ", out, o.Exceprt)
}
... ... @@ -34,16 +30,12 @@ func Benchmark_GenMessage(b *testing.B) {
o := struct {
Rsp interface{}
Error error
Exceprt *mybeego.Message
}{Rsp: "test", Error: fmt.Errorf("test"), Exceprt: mybeego.NewMessage(1)}
Exceprt *protocol.ResponseMessage
}{Rsp: "test", Error: fmt.Errorf("test"), Exceprt: protocol.NewErrWithMessage(1, fmt.Errorf("test-A")).ParseToMessage()}
for i := 0; i < b.N; i++ {
out := DefaultController.GenMessage(o.Rsp, o.Error)
out := protocol.NewReturnResponse(o.Rsp, o.Error)
if out.Errmsg != o.Exceprt.Errmsg || out.Errno != o.Exceprt.Errno {
log.Fatal("not equal ", out, o.Exceprt)
}
}
}
func TestXXX(t *testing.T) {
t.Log(time.Now())
}
... ...
package repository
import "opp/models"
type IConfigRepository interface {
GetCfgClient(clintId, clientSecret string) (v *models.CfgClient, err error)
}
type ConfigRepository struct{}
func (r *ConfigRepository) GetCfgClient(clintId, clientSecret string) (v *models.CfgClient, err error) {
return models.GetCfgClient(clintId, clientSecret)
}
package repository
import "opp/models"
type ConfigMockeRepository struct{}
func (r *ConfigMockeRepository) GetCfgClient(clintId, clientSecret string) (v *models.CfgClient, err error) {
return
}
... ... @@ -2,34 +2,25 @@ package repository
import "sync"
var(
mutex sync.RWMutex
DefaultUserRepository IUserRepository
DefaultConfigRepository IConfigRepository
//全局
var (
once sync.Once
User IUserRepository
UserAuth IUserAuthRepository
)
func init(){
DefaultUserRepository = UserRepositoryFactory()
func init() {
InitRepository()
}
func UserRepositoryFactory()IUserRepository{
if DefaultUserRepository==nil{
mutex.Lock()
defer mutex.Unlock()
if DefaultUserRepository==nil{
DefaultUserRepository = &UserRepository{}
}
}
return DefaultUserRepository
func InitRepository() {
User = &UserRepository{}
UserAuth = &UserAuthRepository{}
}
func ConfigRepositoryFactory()IConfigRepository{
if DefaultConfigRepository==nil{
mutex.Lock()
defer mutex.Unlock()
if DefaultConfigRepository==nil{
DefaultConfigRepository = &ConfigRepository{}
}
}
return DefaultConfigRepository
func InitRepositoryMock() {
once.Do(func() {
User = &UserMockRepository{}
UserAuth = &UserAuthMockRepository{}
})
}
... ...
... ... @@ -3,35 +3,23 @@ package repository
import "opp/models"
type IUserRepository interface {
GetUsersByMobile(mobile string) (v *models.Users, err error)
GetUserInfoByMobile(mobile string) (v *models.UserInfo, err error)
UpdateUserInfoById(m *models.UserInfo) (err error)
GetUserInfoByAuthCode(authCode string) (v *models.UserInfo, err error)
GetUserInfoByRefreshToken(refreshToken string) (v *models.UserInfo, err error)
GetUsersById(uid int64) (v *models.User, err error)
GetUsersByMobile(mobile string) (v *models.User, err error)
UpdateUserInfo(m *models.User) (err error)
}
func assertImplement() {
var _ IUserRepository = (*UserRepository)(nil)
}
var _ IUserRepository = (*UserRepository)(nil)
type UserRepository struct{}
func (r *UserRepository) GetUsersByMobile(mobile string) (v *models.Users, err error) {
return models.GetUsersByMobile(mobile)
}
func (r *UserRepository) GetUserInfoByMobile(mobile string) (v *models.UserInfo, err error) {
return models.GetUserInfoByMobile(mobile)
func (r *UserRepository) GetUsersById(uid int64) (v *models.User, err error) {
return models.GetUsersById(uid)
}
func (r *UserRepository) UpdateUserInfoById(m *models.UserInfo) (err error) {
return models.UpdateUserInfoById(m)
}
func (r *UserRepository) GetUserInfoByAuthCode(authCode string) (v *models.UserInfo, err error) {
return models.GetUserInfoByAuthCode(authCode)
func (r *UserRepository) GetUsersByMobile(mobile string) (v *models.User, err error) {
return models.GetUsersByMobile(mobile)
}
func (r *UserRepository) GetUserInfoByRefreshToken(refreshToken string) (v *models.UserInfo, err error) {
return models.GetUserInfoByRefreshToken(refreshToken)
func (r *UserRepository) UpdateUserInfo(m *models.User) (err error) {
return models.UpdateUsersById(m)
}
... ...
package repository
import "opp/models"
type IUserAuthRepository interface {
GetUserAuthByUserId(uid int64) (v *models.UserAuth, err error)
UpdateUserAuthById(m *models.UserAuth) (err error)
GetUserAuthByAuthCode(authCode string) (v *models.UserAuth, err error)
GetUserAuthByRefreshToken(refreshToken string) (v *models.UserAuth, err error)
GetUserAuthByToken(refreshToken string) (v *models.UserAuth, err error)
}
var _ IUserAuthRepository = (*UserAuthRepository)(nil)
type UserAuthRepository struct{}
func (r *UserAuthRepository) GetUserAuthByUserId(uid int64) (v *models.UserAuth, err error) {
return models.GetUserAuthByUserId(uid)
}
func (r *UserAuthRepository) UpdateUserAuthById(m *models.UserAuth) (err error) {
return models.UpdateUserAuthById(m)
}
func (r *UserAuthRepository) GetUserAuthByAuthCode(authCode string) (v *models.UserAuth, err error) {
return models.GetUserByAuthCode(authCode)
}
func (r *UserAuthRepository) GetUserAuthByRefreshToken(refreshToken string) (v *models.UserAuth, err error) {
return models.GetUserAuthByRefreshToken(refreshToken)
}
func (r *UserAuthRepository) GetUserAuthByToken(refreshToken string) (v *models.UserAuth, err error) {
return models.GetUserAuthByToken(refreshToken)
}
... ...
package repository
import "opp/models"
var userAuth = &models.UserAuth{
AuthCode: "897ca746f46b11e98771000c29ad8d6d",
AccessToken: "897ca746f46b11e98771000c29ad8d7d",
RefreshToken: "897ca746f46b11e98771000c29ad8d8d",
}
type UserAuthMockRepository struct{}
func (r *UserAuthMockRepository) GetUserAuthByUserId(uid int64) (v *models.UserAuth, err error) {
v = userAuth
return
}
func (r *UserAuthMockRepository) UpdateUserAuthById(m *models.UserAuth) (err error) {
return
}
func (r *UserAuthMockRepository) GetUserAuthByAuthCode(authCode string) (v *models.UserAuth, err error) {
v = userAuth
return
}
func (r *UserAuthMockRepository) GetUserAuthByRefreshToken(refreshToken string) (v *models.UserAuth, err error) {
v = userAuth
return
}
func (r *UserAuthMockRepository) GetUserAuthByToken(refreshToken string) (v *models.UserAuth, err error) {
v = userAuth
return
}
... ...
... ... @@ -4,35 +4,27 @@ import "opp/models"
type UserMockRepository struct{}
var userInfo = &models.UserInfo{
Auth: "897ca746f46b11e98771000c29ad8d6d",
var userInfo = &models.UserAuth{
AuthCode: "897ca746f46b11e98771000c29ad8d6d",
AccessToken: "897ca746f46b11e98771000c29ad8d7d",
RefreshToken: "897ca746f46b11e98771000c29ad8d8d",
}
func (r *UserMockRepository) GetUsersByMobile(mobile string) (v *models.Users, err error) {
v = &models.Users{
Username: "18065048389",
Password: "$2y$10$YWg7jPRVLBzc3kevokMkW.boswtCvhToqC.TappIwfqwJ.cI0efvy",
}
return
}
func (r *UserMockRepository) GetUserInfoByMobile(mobile string) (v *models.UserInfo, err error) {
v = userInfo
return
var user = &models.User{
Phone: "18065048389",
Passwd: "$2y$10$YWg7jPRVLBzc3kevokMkW.boswtCvhToqC.TappIwfqwJ.cI0efvy",
}
func (r *UserMockRepository) UpdateUserInfoById(m *models.UserInfo) (err error) {
func (r *UserMockRepository) GetUsersById(uid int64) (v *models.User, err error) {
v = user
return
}
func (r *UserMockRepository) GetUserInfoByAuthCode(authCode string) (v *models.UserInfo, err error) {
v = userInfo
func (r *UserMockRepository) GetUsersByMobile(mobile string) (v *models.User, err error) {
v = user
return
}
func (r *UserMockRepository) GetUserInfoByRefreshToken(refreshToken string) (v *models.UserInfo, err error) {
v = userInfo
func (r *UserMockRepository) UpdateUserInfo(m *models.User) (err error) {
return
}
... ...
... ... @@ -34,7 +34,7 @@ func init() {
//panic(err)
}
orm.NewBeeormEngine(config.Mysql{
AliasName: "default",
//AliasName: "default",
DataSource: beego.AppConfig.String("data_source"),
MaxIdle: 100,
MaxOpen: 100,
... ...
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type Announcement struct {
Id int `orm:"column(id);pk" description:"主键ID"`
CreateTime time.Time `orm:"column(createTime);type(timestamp);auto_now_add" description:"创建时间"`
Content string `orm:"column(content);size(500)" description:"消息标题"`
CompanyId int64 `orm:"column(company_id);null"`
Day string `orm:"column(day);size(20)" description:"日期"`
}
func (t *Announcement) TableName() string {
return "announcement"
}
func init() {
orm.RegisterModel(new(Announcement))
}
// AddAnnouncement insert a new Announcement into database and returns
// last inserted Id on success.
func AddAnnouncement(m *Announcement) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetAnnouncementById retrieves Announcement by Id. Returns error if
// Id doesn't exist
func GetAnnouncementById(id int) (v *Announcement, err error) {
o := orm.NewOrm()
v = &Announcement{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllAnnouncement retrieves all Announcement matches certain condition. Returns empty list if
// no records exist
func GetAllAnnouncement(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(Announcement))
// 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 []Announcement
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
}
// UpdateAnnouncement updates Announcement by Id and returns error if
// the record to be updated doesn't exist
func UpdateAnnouncementById(m *Announcement) (err error) {
o := orm.NewOrm()
v := Announcement{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
}
// DeleteAnnouncement deletes Announcement by Id and returns error if
// the record to be deleted doesn't exist
func DeleteAnnouncement(id int) (err error) {
o := orm.NewOrm()
v := Announcement{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&Announcement{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type BonusPoint struct {
Id int `orm:"column(id);pk"`
CompanyId int `orm:"column(company_id)" description:"公司ID"`
Type int8 `orm:"column(type)" description:"加分类型 0发现 1分析 2解决"`
Uid int64 `orm:"column(uid)" description:"被加分人"`
Score int `orm:"column(score)" description:"加分数值"`
JoinDate time.Time `orm:"column(join_date);type(date)" description:"加入年月"`
OperatorId int64 `orm:"column(operator_id)" description:"加分人(操作者id)"`
Reason string `orm:"column(reason);size(500);null" description:"加分理由"`
CreateTime time.Time `orm:"column(createTime);type(timestamp);auto_now_add"`
UpdateTime time.Time `orm:"column(updateTime);type(timestamp);auto_now_add"`
}
func (t *BonusPoint) TableName() string {
return "bonus_point"
}
func init() {
orm.RegisterModel(new(BonusPoint))
}
// AddBonusPoint insert a new BonusPoint into database and returns
// last inserted Id on success.
func AddBonusPoint(m *BonusPoint) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetBonusPointById retrieves BonusPoint by Id. Returns error if
// Id doesn't exist
func GetBonusPointById(id int) (v *BonusPoint, err error) {
o := orm.NewOrm()
v = &BonusPoint{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllBonusPoint retrieves all BonusPoint matches certain condition. Returns empty list if
// no records exist
func GetAllBonusPoint(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(BonusPoint))
// 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 []BonusPoint
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
}
// UpdateBonusPoint updates BonusPoint by Id and returns error if
// the record to be updated doesn't exist
func UpdateBonusPointById(m *BonusPoint) (err error) {
o := orm.NewOrm()
v := BonusPoint{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
}
// DeleteBonusPoint deletes BonusPoint by Id and returns error if
// the record to be deleted doesn't exist
func DeleteBonusPoint(id int) (err error) {
o := orm.NewOrm()
v := BonusPoint{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&BonusPoint{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type Bulletin struct {
Id int `orm:"column(id);auto"`
Title string `orm:"column(title);size(2000);null" description:"标题"`
Content string `orm:"column(content);null" description:"内容"`
Cover string `orm:"column(cover);size(255);null" description:"封面地址"`
W int `orm:"column(w);null" description:"宽"`
H int `orm:"column(h);null" description:"高"`
Type int8 `orm:"column(type);null" description:"公告类型(0图+跳转链接、1链接)"`
Receiver string `orm:"column(receiver);null" description:"接收者"`
QuestionSwitch int8 `orm:"column(question_switch);null" description:"设置问题开关"`
CreateTime time.Time `orm:"column(createTime);type(timestamp);null" description:"创建时间"`
UpdateTime time.Time `orm:"column(updateTime);type(timestamp);null" description:"更新时间"`
AllowClose int8 `orm:"column(allowClose);null" description:"允许关闭公告(0允许,1禁止)"`
CompanyId int `orm:"column(company_id);null" description:"公司Id"`
Status uint8 `orm:"column(status)" description:"状态 0-下架 1- 上架"`
}
func (t *Bulletin) TableName() string {
return "bulletin"
}
func init() {
orm.RegisterModel(new(Bulletin))
}
// AddBulletin insert a new Bulletin into database and returns
// last inserted Id on success.
func AddBulletin(m *Bulletin) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetBulletinById retrieves Bulletin by Id. Returns error if
// Id doesn't exist
func GetBulletinById(id int) (v *Bulletin, err error) {
o := orm.NewOrm()
v = &Bulletin{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllBulletin retrieves all Bulletin matches certain condition. Returns empty list if
// no records exist
func GetAllBulletin(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(Bulletin))
// 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 []Bulletin
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
}
// UpdateBulletin updates Bulletin by Id and returns error if
// the record to be updated doesn't exist
func UpdateBulletinById(m *Bulletin) (err error) {
o := orm.NewOrm()
v := Bulletin{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
}
// DeleteBulletin deletes Bulletin by Id and returns error if
// the record to be deleted doesn't exist
func DeleteBulletin(id int) (err error) {
o := orm.NewOrm()
v := Bulletin{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&Bulletin{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type BulletinQuestion struct {
Id int `orm:"column(id);auto"`
BulletinId int `orm:"column(bulletin_id);null" description:"公告id"`
Type int8 `orm:"column(type);null" description:"类型:0-单选,1-多选"`
Title string `orm:"column(title);size(2000);null" description:"标题"`
Content string `orm:"column(content);size(2000);null" description:"内容"`
CreateTime time.Time `orm:"column(createTime);type(timestamp);null" description:"创建时间"`
UpdateTime time.Time `orm:"column(updateTime);type(timestamp);null" description:"更新时间"`
}
func (t *BulletinQuestion) TableName() string {
return "bulletin_question"
}
func init() {
orm.RegisterModel(new(BulletinQuestion))
}
// AddBulletinQuestion insert a new BulletinQuestion into database and returns
// last inserted Id on success.
func AddBulletinQuestion(m *BulletinQuestion) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetBulletinQuestionById retrieves BulletinQuestion by Id. Returns error if
// Id doesn't exist
func GetBulletinQuestionById(id int) (v *BulletinQuestion, err error) {
o := orm.NewOrm()
v = &BulletinQuestion{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllBulletinQuestion retrieves all BulletinQuestion matches certain condition. Returns empty list if
// no records exist
func GetAllBulletinQuestion(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(BulletinQuestion))
// 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 []BulletinQuestion
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
}
// UpdateBulletinQuestion updates BulletinQuestion by Id and returns error if
// the record to be updated doesn't exist
func UpdateBulletinQuestionById(m *BulletinQuestion) (err error) {
o := orm.NewOrm()
v := BulletinQuestion{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
}
// DeleteBulletinQuestion deletes BulletinQuestion by Id and returns error if
// the record to be deleted doesn't exist
func DeleteBulletinQuestion(id int) (err error) {
o := orm.NewOrm()
v := BulletinQuestion{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&BulletinQuestion{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type BulletinQuestionAnswer struct {
Id int `orm:"column(id);auto"`
Answer string `orm:"column(answer);null" description:"答案"`
BulletinId int `orm:"column(bulletin_id);null" description:"公告id"`
BulletinQuestionId int `orm:"column(bulletin_question_id);null" description:"公告问题id"`
Uid int64 `orm:"column(uid);null" description:"用户id"`
CreateTime time.Time `orm:"column(createTime);type(timestamp);null" description:"创建时间"`
UpdateTime time.Time `orm:"column(updateTime);type(timestamp);null" description:"更新时间"`
}
func (t *BulletinQuestionAnswer) TableName() string {
return "bulletin_question_answer"
}
func init() {
orm.RegisterModel(new(BulletinQuestionAnswer))
}
// AddBulletinQuestionAnswer insert a new BulletinQuestionAnswer into database and returns
// last inserted Id on success.
func AddBulletinQuestionAnswer(m *BulletinQuestionAnswer) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetBulletinQuestionAnswerById retrieves BulletinQuestionAnswer by Id. Returns error if
// Id doesn't exist
func GetBulletinQuestionAnswerById(id int) (v *BulletinQuestionAnswer, err error) {
o := orm.NewOrm()
v = &BulletinQuestionAnswer{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllBulletinQuestionAnswer retrieves all BulletinQuestionAnswer matches certain condition. Returns empty list if
// no records exist
func GetAllBulletinQuestionAnswer(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(BulletinQuestionAnswer))
// 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 []BulletinQuestionAnswer
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
}
// UpdateBulletinQuestionAnswer updates BulletinQuestionAnswer by Id and returns error if
// the record to be updated doesn't exist
func UpdateBulletinQuestionAnswerById(m *BulletinQuestionAnswer) (err error) {
o := orm.NewOrm()
v := BulletinQuestionAnswer{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
}
// DeleteBulletinQuestionAnswer deletes BulletinQuestionAnswer by Id and returns error if
// the record to be deleted doesn't exist
func DeleteBulletinQuestionAnswer(id int) (err error) {
o := orm.NewOrm()
v := BulletinQuestionAnswer{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&BulletinQuestionAnswer{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
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
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type CfgAttr struct {
Id int `orm:"column(id);auto" description:"主键ID"`
CompanyId int `orm:"column(company_id)" description:"公司Id"`
Name string `orm:"column(name);size(200)" description:"名称"`
Sort uint `orm:"column(sort)" description:"排序"`
CreateTime time.Time `orm:"column(createTime);type(timestamp);auto_now_add" description:"创建时间"`
Enabled int `orm:"column(enabled)"`
}
func (t *CfgAttr) TableName() string {
return "cfg_attr"
}
func init() {
orm.RegisterModel(new(CfgAttr))
}
// AddCfgAttr insert a new CfgAttr into database and returns
// last inserted Id on success.
func AddCfgAttr(m *CfgAttr) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetCfgAttrById retrieves CfgAttr by Id. Returns error if
// Id doesn't exist
func GetCfgAttrById(id int) (v *CfgAttr, err error) {
o := orm.NewOrm()
v = &CfgAttr{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllCfgAttr retrieves all CfgAttr matches certain condition. Returns empty list if
// no records exist
func GetAllCfgAttr(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(CfgAttr))
// 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 []CfgAttr
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
}
// UpdateCfgAttr updates CfgAttr by Id and returns error if
// the record to be updated doesn't exist
func UpdateCfgAttrById(m *CfgAttr) (err error) {
o := orm.NewOrm()
v := CfgAttr{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
}
// DeleteCfgAttr deletes CfgAttr by Id and returns error if
// the record to be deleted doesn't exist
func DeleteCfgAttr(id int) (err error) {
o := orm.NewOrm()
v := CfgAttr{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&CfgAttr{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type CfgClient struct {
Id int `orm:"column(id);auto" description:"主键ID"`
ClientId string `orm:"column(client_id);size(32)" description:"客户端ID"`
ClientSecret string `orm:"column(client_secret);size(128);null" description:"客户端密钥"`
CreateTime time.Time `orm:"column(create_time);type(timestamp);auto_now" description:"创建时间"`
Enabled int8 `orm:"column(enabled)" description:"是否有效"`
}
func (t *CfgClient) TableName() string {
return "cfg_client"
}
func init() {
orm.RegisterModel(new(CfgClient))
}
// AddCfgClient insert a new CfgClient into database and returns
// last inserted Id on success.
func AddCfgClient(m *CfgClient) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetCfgClientById retrieves CfgClient by Id. Returns error if
// Id doesn't exist
func GetCfgClientById(id int) (v *CfgClient, err error) {
o := orm.NewOrm()
v = &CfgClient{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllCfgClient retrieves all CfgClient matches certain condition. Returns empty list if
// no records exist
func GetAllCfgClient(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(CfgClient))
// 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 []CfgClient
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
}
// UpdateCfgClient updates CfgClient by Id and returns error if
// the record to be updated doesn't exist
func UpdateCfgClientById(m *CfgClient) (err error) {
o := orm.NewOrm()
v := CfgClient{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
}
// DeleteCfgClient deletes CfgClient by Id and returns error if
// the record to be deleted doesn't exist
func DeleteCfgClient(id int) (err error) {
o := orm.NewOrm()
v := CfgClient{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&CfgClient{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
func GetCfgClient(clintId, clientSecret string) (v *CfgClient, err error) {
o := orm.NewOrm()
sql := "select * from cfg_client where enabled=1 and client_id=? and client_secret=?"
if err = o.Raw(sql, clintId, clientSecret).QueryRow(&v); err == nil {
return v, nil
}
return nil, err
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type CfgMsg struct {
Id int `orm:"column(id);pk" description:"主键ID"`
CreateTime time.Time `orm:"column(createTime);type(timestamp);auto_now_add" description:"创建时间"`
Title string `orm:"column(title);size(100)" description:"消息标题"`
Type int `orm:"column(type)" description:"1为某某某代表解决 2为某某某提出 3为某某某申请解决"`
}
func (t *CfgMsg) TableName() string {
return "cfg_msg"
}
func init() {
orm.RegisterModel(new(CfgMsg))
}
// AddCfgMsg insert a new CfgMsg into database and returns
// last inserted Id on success.
func AddCfgMsg(m *CfgMsg) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetCfgMsgById retrieves CfgMsg by Id. Returns error if
// Id doesn't exist
func GetCfgMsgById(id int) (v *CfgMsg, err error) {
o := orm.NewOrm()
v = &CfgMsg{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllCfgMsg retrieves all CfgMsg matches certain condition. Returns empty list if
// no records exist
func GetAllCfgMsg(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(CfgMsg))
// 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 []CfgMsg
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
}
// UpdateCfgMsg updates CfgMsg by Id and returns error if
// the record to be updated doesn't exist
func UpdateCfgMsgById(m *CfgMsg) (err error) {
o := orm.NewOrm()
v := CfgMsg{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
}
// DeleteCfgMsg deletes CfgMsg by Id and returns error if
// the record to be deleted doesn't exist
func DeleteCfgMsg(id int) (err error) {
o := orm.NewOrm()
v := CfgMsg{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&CfgMsg{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type Commend struct {
Id int `orm:"column(cid);pk" description:"主键ID"`
Uid int64 `orm:"column(uid)" description:"用户ID"`
Username string `orm:"column(username);size(255)" description:"用户名"`
CreateTime time.Time `orm:"column(createTime);type(timestamp);auto_now_add" description:"创建时间"`
QuestionTitle string `orm:"column(questionTitle);size(100)" description:"标题"`
QuestionId int64 `orm:"column(questionId);null"`
Way int `orm:"column(way)" description:"0提出问题、1参与解决问题"`
Company string `orm:"column(company);size(50)" description:"是否已读 0未读,1已读"`
CompanyId int `orm:"column(company_id)" description:"公司id"`
Status int8 `orm:"column(status)" description:"状态 1可见 2不可见"`
CommendationTime time.Time `orm:"column(commendation_time);type(date)" description:"表彰时间"`
}
func (t *Commend) TableName() string {
return "commend"
}
func init() {
orm.RegisterModel(new(Commend))
}
// AddCommend insert a new Commend into database and returns
// last inserted Id on success.
func AddCommend(m *Commend) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetCommendById retrieves Commend by Id. Returns error if
// Id doesn't exist
func GetCommendById(id int) (v *Commend, err error) {
o := orm.NewOrm()
v = &Commend{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllCommend retrieves all Commend matches certain condition. Returns empty list if
// no records exist
func GetAllCommend(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(Commend))
// 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 []Commend
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
}
// UpdateCommend updates Commend by Id and returns error if
// the record to be updated doesn't exist
func UpdateCommendById(m *Commend) (err error) {
o := orm.NewOrm()
v := Commend{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
}
// DeleteCommend deletes Commend by Id and returns error if
// the record to be deleted doesn't exist
func DeleteCommend(id int) (err error) {
o := orm.NewOrm()
v := Commend{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&Commend{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type Comment struct {
Id int `orm:"column(cid);pk"`
Uid int64 `orm:"column(uid);null"`
CreateTime time.Time `orm:"column(createTime);type(timestamp);auto_now_add"`
Content string `orm:"column(content)"`
PageView int `orm:"column(pageView);null" description:"浏览总数"`
CommentTotal int `orm:"column(commentTotal);null" description:"评论总数"`
SympathyTotal int `orm:"column(sympathyTotal)" description:"同感总数"`
Type int `orm:"column(type);null" description:"0问题、1评论、2方案"`
Id_RENAME int64 `orm:"column(id);null" description:"对应的ID"`
}
func (t *Comment) TableName() string {
return "comment"
}
func init() {
orm.RegisterModel(new(Comment))
}
// AddComment insert a new Comment into database and returns
// last inserted Id on success.
func AddComment(m *Comment) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetCommentById retrieves Comment by Id. Returns error if
// Id doesn't exist
func GetCommentById(id int) (v *Comment, err error) {
o := orm.NewOrm()
v = &Comment{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllComment retrieves all Comment matches certain condition. Returns empty list if
// no records exist
func GetAllComment(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(Comment))
// 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 []Comment
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
}
// UpdateComment updates Comment by Id and returns error if
// the record to be updated doesn't exist
func UpdateCommentById(m *Comment) (err error) {
o := orm.NewOrm()
v := Comment{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
}
// DeleteComment deletes Comment by Id and returns error if
// the record to be deleted doesn't exist
func DeleteComment(id int) (err error) {
o := orm.NewOrm()
v := Comment{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&Comment{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type Companies struct {
Id int `orm:"column(id);auto"`
Name string `orm:"column(name);size(255)"`
Username string `orm:"column(username);size(255)"`
Phone string `orm:"column(phone);size(255)"`
Status uint8 `orm:"column(status)" description:"状态 1启用 2禁用"`
CreateTime time.Time `orm:"column(create_time);type(timestamp);auto_now"`
}
func (t *Companies) TableName() string {
return "companies"
}
func init() {
orm.RegisterModel(new(Companies))
}
// AddCompanies insert a new Companies into database and returns
// last inserted Id on success.
func AddCompanies(m *Companies) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetCompaniesById retrieves Companies by Id. Returns error if
// Id doesn't exist
func GetCompaniesById(id int) (v *Companies, err error) {
o := orm.NewOrm()
v = &Companies{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllCompanies retrieves all Companies matches certain condition. Returns empty list if
// no records exist
func GetAllCompanies(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(Companies))
// 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 []Companies
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
}
// UpdateCompanies updates Companies by Id and returns error if
// the record to be updated doesn't exist
func UpdateCompaniesById(m *Companies) (err error) {
o := orm.NewOrm()
v := Companies{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
}
// DeleteCompanies deletes Companies by Id and returns error if
// the record to be deleted doesn't exist
func DeleteCompanies(id int) (err error) {
o := orm.NewOrm()
v := Companies{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&Companies{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type Departments struct {
Id int `orm:"column(id);auto"`
CompanyId int `orm:"column(company_id)"`
Name string `orm:"column(name);size(255)"`
Username string `orm:"column(username);size(255)"`
Number int `orm:"column(number)"`
CreateTime time.Time `orm:"column(create_time);type(timestamp);auto_now"`
Enabled uint8 `orm:"column(enabled)" description:"状态 1启用 0禁用"`
}
func (t *Departments) TableName() string {
return "departments"
}
func init() {
orm.RegisterModel(new(Departments))
}
// AddDepartments insert a new Departments into database and returns
// last inserted Id on success.
func AddDepartments(m *Departments) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetDepartmentsById retrieves Departments by Id. Returns error if
// Id doesn't exist
func GetDepartmentsById(id int) (v *Departments, err error) {
o := orm.NewOrm()
v = &Departments{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllDepartments retrieves all Departments matches certain condition. Returns empty list if
// no records exist
func GetAllDepartments(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(Departments))
// 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 []Departments
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
}
// UpdateDepartments updates Departments by Id and returns error if
// the record to be updated doesn't exist
func UpdateDepartmentsById(m *Departments) (err error) {
o := orm.NewOrm()
v := Departments{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
}
// DeleteDepartments deletes Departments by Id and returns error if
// the record to be deleted doesn't exist
func DeleteDepartments(id int) (err error) {
o := orm.NewOrm()
v := Departments{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&Departments{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"github.com/astaxie/beego/orm"
)
type LogUuid struct {
Id int64 `orm:"column(id);auto" description:"主键ID"`
Uuid string `orm:"column(uuid);size(128)"`
}
func (t *LogUuid) TableName() string {
return "log_uuid"
}
func init() {
orm.RegisterModel(new(LogUuid))
}
// AddLogUuid insert a new LogUuid into database and returns
// last inserted Id on success.
func AddLogUuid(m *LogUuid) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetLogUuidById retrieves LogUuid by Id. Returns error if
// Id doesn't exist
func GetLogUuidById(id int64) (v *LogUuid, err error) {
o := orm.NewOrm()
v = &LogUuid{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllLogUuid retrieves all LogUuid matches certain condition. Returns empty list if
// no records exist
func GetAllLogUuid(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(LogUuid))
// 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 []LogUuid
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
}
// UpdateLogUuid updates LogUuid by Id and returns error if
// the record to be updated doesn't exist
func UpdateLogUuidById(m *LogUuid) (err error) {
o := orm.NewOrm()
v := LogUuid{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
}
// DeleteLogUuid deletes LogUuid by Id and returns error if
// the record to be deleted doesn't exist
func DeleteLogUuid(id int64) (err error) {
o := orm.NewOrm()
v := LogUuid{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&LogUuid{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
func GetLogUuidByUuid(uuid string) (v *LogUuid, err error) {
o := orm.NewOrm()
sql := "select * from log_uuid where uuid=?"
if err = o.Raw(sql, uuid).QueryRow(&v); err == nil {
return v, nil
}
return nil, err
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"github.com/astaxie/beego/orm"
)
type Logic struct {
Id int `orm:"column(id);auto"`
Data string `orm:"column(data);null"`
Db string `orm:"column(db);size(50);null"`
Datatype string `orm:"column(datatype);size(50);null"`
Type string `orm:"column(type);size(100);null"`
Defaultparam string `orm:"column(defaultparam);size(200);null"`
}
func (t *Logic) TableName() string {
return "logic"
}
func init() {
orm.RegisterModel(new(Logic))
}
// AddLogic insert a new Logic into database and returns
// last inserted Id on success.
func AddLogic(m *Logic) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetLogicById retrieves Logic by Id. Returns error if
// Id doesn't exist
func GetLogicById(id int) (v *Logic, err error) {
o := orm.NewOrm()
v = &Logic{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllLogic retrieves all Logic matches certain condition. Returns empty list if
// no records exist
func GetAllLogic(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(Logic))
// 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 []Logic
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
}
// UpdateLogic updates Logic by Id and returns error if
// the record to be updated doesn't exist
func UpdateLogicById(m *Logic) (err error) {
o := orm.NewOrm()
v := Logic{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
}
// DeleteLogic deletes Logic by Id and returns error if
// the record to be deleted doesn't exist
func DeleteLogic(id int) (err error) {
o := orm.NewOrm()
v := Logic{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&Logic{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"github.com/astaxie/beego/orm"
)
type Permissions struct {
Id int `orm:"column(id);auto"`
Name string `orm:"column(name);size(255)"`
Value int8 `orm:"column(value)"`
}
func (t *Permissions) TableName() string {
return "permissions"
}
func init() {
orm.RegisterModel(new(Permissions))
}
// AddPermissions insert a new Permissions into database and returns
// last inserted Id on success.
func AddPermissions(m *Permissions) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetPermissionsById retrieves Permissions by Id. Returns error if
// Id doesn't exist
func GetPermissionsById(id int) (v *Permissions, err error) {
o := orm.NewOrm()
v = &Permissions{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllPermissions retrieves all Permissions matches certain condition. Returns empty list if
// no records exist
func GetAllPermissions(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(Permissions))
// 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 []Permissions
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
}
// UpdatePermissions updates Permissions by Id and returns error if
// the record to be updated doesn't exist
func UpdatePermissionsById(m *Permissions) (err error) {
o := orm.NewOrm()
v := Permissions{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
}
// DeletePermissions deletes Permissions by Id and returns error if
// the record to be deleted doesn't exist
func DeletePermissions(id int) (err error) {
o := orm.NewOrm()
v := Permissions{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&Permissions{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"github.com/astaxie/beego/orm"
)
type PicsLog struct {
Id int `orm:"column(id);auto" description:"主键ID"`
Url string `orm:"column(url);size(128)"`
Thumbnail string `orm:"column(thumbnail);size(128)" description:"缩略图"`
Width int `orm:"column(width)" description:"宽度"`
Length int `orm:"column(length)" description:"长度"`
}
func (t *PicsLog) TableName() string {
return "pics_log"
}
func init() {
orm.RegisterModel(new(PicsLog))
}
// AddPicsLog insert a new PicsLog into database and returns
// last inserted Id on success.
func AddPicsLog(m *PicsLog) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetPicsLogById retrieves PicsLog by Id. Returns error if
// Id doesn't exist
func GetPicsLogById(id int) (v *PicsLog, err error) {
o := orm.NewOrm()
v = &PicsLog{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllPicsLog retrieves all PicsLog matches certain condition. Returns empty list if
// no records exist
func GetAllPicsLog(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(PicsLog))
// 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 []PicsLog
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
}
// UpdatePicsLog updates PicsLog by Id and returns error if
// the record to be updated doesn't exist
func UpdatePicsLogById(m *PicsLog) (err error) {
o := orm.NewOrm()
v := PicsLog{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
}
// DeletePicsLog deletes PicsLog by Id and returns error if
// the record to be deleted doesn't exist
func DeletePicsLog(id int) (err error) {
o := orm.NewOrm()
v := PicsLog{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&PicsLog{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type Positions struct {
Id int `orm:"column(id);auto"`
CompanyId int `orm:"column(company_id)"`
Name string `orm:"column(name);size(255)"`
Pid string `orm:"column(pid);size(255)"`
Path string `orm:"column(path);size(1000)"`
Level int8 `orm:"column(level)" description:"级别"`
CreateTime time.Time `orm:"column(create_time);type(timestamp);auto_now"`
Enabled int8 `orm:"column(enabled)"`
}
func (t *Positions) TableName() string {
return "positions"
}
func init() {
orm.RegisterModel(new(Positions))
}
// AddPositions insert a new Positions into database and returns
// last inserted Id on success.
func AddPositions(m *Positions) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetPositionsById retrieves Positions by Id. Returns error if
// Id doesn't exist
func GetPositionsById(id int) (v *Positions, err error) {
o := orm.NewOrm()
v = &Positions{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllPositions retrieves all Positions matches certain condition. Returns empty list if
// no records exist
func GetAllPositions(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(Positions))
// 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 []Positions
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
}
// UpdatePositions updates Positions by Id and returns error if
// the record to be updated doesn't exist
func UpdatePositionsById(m *Positions) (err error) {
o := orm.NewOrm()
v := Positions{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
}
// DeletePositions deletes Positions by Id and returns error if
// the record to be deleted doesn't exist
func DeletePositions(id int) (err error) {
o := orm.NewOrm()
v := Positions{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&Positions{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type Question struct {
Id int `orm:"column(id);pk"`
Title string `orm:"column(title);size(30)" description:"标题"`
Content string `orm:"column(content)" description:"内容"`
Uid int64 `orm:"column(uid)" description:"用户ID"`
CreateTime time.Time `orm:"column(createTime);type(timestamp);auto_now_add"`
Way int `orm:"column(way)" description:"提问方式(0语音,1图文)"`
PageView int `orm:"column(pageView)" description:"浏览总数"`
CommentTotal int `orm:"column(commentTotal)" description:"评论总数"`
SympathyTotal int `orm:"column(sympathyTotal)" description:"同感总数"`
Review int `orm:"column(review)" description:"0 待审核 1已审核"`
Status int `orm:"column(status);null" description:"状态 0 未解决 1已解决"`
UpdateTime time.Time `orm:"column(updateTime);type(timestamp);null"`
ScoreAnalyze int `orm:"column(scoreAnalyze);null" description:"分析评分"`
ScoreAsk int `orm:"column(scoreAsk);null" description:"提问评分"`
ScoreScheme int `orm:"column(scoreScheme);null" description:"方案评分"`
Published int `orm:"column(published);null" description:"公开状态 0未公开、1本部门公开、2本公司公开"`
Level int `orm:"column(level)" description:"最后评分或审核人的级别"`
CheckUid int64 `orm:"column(checkUid);null" description:"审核人ID"`
Enabled int `orm:"column(enabled);null" description:"1有效 0删除"`
Tlevel int `orm:"column(tlevel)" description:"公开操作权限"`
PfUid int64 `orm:"column(pfUid)"`
QType int `orm:"column(qType)"`
SoluteTime time.Time `orm:"column(soluteTime);type(timestamp);auto_now_add"`
ResolverTime time.Time `orm:"column(resolverTime);type(timestamp);auto_now_add"`
Resolver int64 `orm:"column(resolver)"`
RelevantDepartmentId int `orm:"column(relevantDepartmentId)" description:"相关部门id"`
ReceiveStatus int8 `orm:"column(receiveStatus)" description:"领取状态 0未领取 1已领取"`
}
func (t *Question) TableName() string {
return "question"
}
func init() {
orm.RegisterModel(new(Question))
}
// AddQuestion insert a new Question into database and returns
// last inserted Id on success.
func AddQuestion(m *Question) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetQuestionById retrieves Question by Id. Returns error if
// Id doesn't exist
func GetQuestionById(id int) (v *Question, err error) {
o := orm.NewOrm()
v = &Question{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllQuestion retrieves all Question matches certain condition. Returns empty list if
// no records exist
func GetAllQuestion(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(Question))
// 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 []Question
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
}
// UpdateQuestion updates Question by Id and returns error if
// the record to be updated doesn't exist
func UpdateQuestionById(m *Question) (err error) {
o := orm.NewOrm()
v := Question{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
}
// DeleteQuestion deletes Question by Id and returns error if
// the record to be deleted doesn't exist
func DeleteQuestion(id int) (err error) {
o := orm.NewOrm()
v := Question{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&Question{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type QuestionDepartment struct {
Id int `orm:"column(id);pk"`
Qid int64 `orm:"column(qid)" description:"所属的问题ID"`
DepartmentId int `orm:"column(department_id)" description:"语音路径"`
CreateTime time.Time `orm:"column(createTime);type(timestamp);auto_now_add"`
}
func (t *QuestionDepartment) TableName() string {
return "question_department"
}
func init() {
orm.RegisterModel(new(QuestionDepartment))
}
// AddQuestionDepartment insert a new QuestionDepartment into database and returns
// last inserted Id on success.
func AddQuestionDepartment(m *QuestionDepartment) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetQuestionDepartmentById retrieves QuestionDepartment by Id. Returns error if
// Id doesn't exist
func GetQuestionDepartmentById(id int) (v *QuestionDepartment, err error) {
o := orm.NewOrm()
v = &QuestionDepartment{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllQuestionDepartment retrieves all QuestionDepartment matches certain condition. Returns empty list if
// no records exist
func GetAllQuestionDepartment(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(QuestionDepartment))
// 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 []QuestionDepartment
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
}
// UpdateQuestionDepartment updates QuestionDepartment by Id and returns error if
// the record to be updated doesn't exist
func UpdateQuestionDepartmentById(m *QuestionDepartment) (err error) {
o := orm.NewOrm()
v := QuestionDepartment{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
}
// DeleteQuestionDepartment deletes QuestionDepartment by Id and returns error if
// the record to be deleted doesn't exist
func DeleteQuestionDepartment(id int) (err error) {
o := orm.NewOrm()
v := QuestionDepartment{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&QuestionDepartment{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type QuestionDepartmentLog struct {
Id int `orm:"column(id);pk"`
Qid int64 `orm:"column(qid)" description:"所属的问题ID"`
DepartmentId int `orm:"column(department_id)" description:"相关部门id"`
OperatorId int64 `orm:"column(operator_id)" description:"操作者id"`
CreateTime time.Time `orm:"column(createTime);type(timestamp);auto_now_add"`
}
func (t *QuestionDepartmentLog) TableName() string {
return "question_department_log"
}
func init() {
orm.RegisterModel(new(QuestionDepartmentLog))
}
// AddQuestionDepartmentLog insert a new QuestionDepartmentLog into database and returns
// last inserted Id on success.
func AddQuestionDepartmentLog(m *QuestionDepartmentLog) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetQuestionDepartmentLogById retrieves QuestionDepartmentLog by Id. Returns error if
// Id doesn't exist
func GetQuestionDepartmentLogById(id int) (v *QuestionDepartmentLog, err error) {
o := orm.NewOrm()
v = &QuestionDepartmentLog{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllQuestionDepartmentLog retrieves all QuestionDepartmentLog matches certain condition. Returns empty list if
// no records exist
func GetAllQuestionDepartmentLog(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(QuestionDepartmentLog))
// 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 []QuestionDepartmentLog
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
}
// UpdateQuestionDepartmentLog updates QuestionDepartmentLog by Id and returns error if
// the record to be updated doesn't exist
func UpdateQuestionDepartmentLogById(m *QuestionDepartmentLog) (err error) {
o := orm.NewOrm()
v := QuestionDepartmentLog{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
}
// DeleteQuestionDepartmentLog deletes QuestionDepartmentLog by Id and returns error if
// the record to be deleted doesn't exist
func DeleteQuestionDepartmentLog(id int) (err error) {
o := orm.NewOrm()
v := QuestionDepartmentLog{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&QuestionDepartmentLog{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"github.com/astaxie/beego/orm"
)
type QuestionImage struct {
Id int `orm:"column(id);pk"`
Qid int64 `orm:"column(qid);null" description:"所属的问题ID"`
Path string `orm:"column(path);size(500);null" description:"语音路径"`
W int `orm:"column(w)"`
H int `orm:"column(h)"`
}
func (t *QuestionImage) TableName() string {
return "question_image"
}
func init() {
orm.RegisterModel(new(QuestionImage))
}
// AddQuestionImage insert a new QuestionImage into database and returns
// last inserted Id on success.
func AddQuestionImage(m *QuestionImage) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetQuestionImageById retrieves QuestionImage by Id. Returns error if
// Id doesn't exist
func GetQuestionImageById(id int) (v *QuestionImage, err error) {
o := orm.NewOrm()
v = &QuestionImage{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllQuestionImage retrieves all QuestionImage matches certain condition. Returns empty list if
// no records exist
func GetAllQuestionImage(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(QuestionImage))
// 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 []QuestionImage
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
}
// UpdateQuestionImage updates QuestionImage by Id and returns error if
// the record to be updated doesn't exist
func UpdateQuestionImageById(m *QuestionImage) (err error) {
o := orm.NewOrm()
v := QuestionImage{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
}
// DeleteQuestionImage deletes QuestionImage by Id and returns error if
// the record to be deleted doesn't exist
func DeleteQuestionImage(id int) (err error) {
o := orm.NewOrm()
v := QuestionImage{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&QuestionImage{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type QuestionScore struct {
Id int `orm:"column(id);pk"`
Uid int64 `orm:"column(uid);null" description:"评分用户ID"`
Qid int64 `orm:"column(qid);null" description:"所属的问题ID"`
ScoreAnalyze int `orm:"column(scoreAnalyze);null"`
ScoreAsk int `orm:"column(scoreAsk);null"`
ScoreScheme int `orm:"column(scoreScheme);null"`
CreateTime time.Time `orm:"column(createTime);type(timestamp);null;auto_now_add" description:"评分时间"`
}
func (t *QuestionScore) TableName() string {
return "question_score"
}
func init() {
orm.RegisterModel(new(QuestionScore))
}
// AddQuestionScore insert a new QuestionScore into database and returns
// last inserted Id on success.
func AddQuestionScore(m *QuestionScore) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetQuestionScoreById retrieves QuestionScore by Id. Returns error if
// Id doesn't exist
func GetQuestionScoreById(id int) (v *QuestionScore, err error) {
o := orm.NewOrm()
v = &QuestionScore{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllQuestionScore retrieves all QuestionScore matches certain condition. Returns empty list if
// no records exist
func GetAllQuestionScore(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(QuestionScore))
// 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 []QuestionScore
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
}
// UpdateQuestionScore updates QuestionScore by Id and returns error if
// the record to be updated doesn't exist
func UpdateQuestionScoreById(m *QuestionScore) (err error) {
o := orm.NewOrm()
v := QuestionScore{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
}
// DeleteQuestionScore deletes QuestionScore by Id and returns error if
// the record to be deleted doesn't exist
func DeleteQuestionScore(id int) (err error) {
o := orm.NewOrm()
v := QuestionScore{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&QuestionScore{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"github.com/astaxie/beego/orm"
)
type QuestionSpeech struct {
Id int `orm:"column(id);pk"`
Duration int `orm:"column(duration);null" description:"秒数"`
Qid int64 `orm:"column(qid);null" description:"所属的问题ID"`
Path string `orm:"column(path);size(500);null" description:"语音路径"`
}
func (t *QuestionSpeech) TableName() string {
return "question_speech"
}
func init() {
orm.RegisterModel(new(QuestionSpeech))
}
// AddQuestionSpeech insert a new QuestionSpeech into database and returns
// last inserted Id on success.
func AddQuestionSpeech(m *QuestionSpeech) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetQuestionSpeechById retrieves QuestionSpeech by Id. Returns error if
// Id doesn't exist
func GetQuestionSpeechById(id int) (v *QuestionSpeech, err error) {
o := orm.NewOrm()
v = &QuestionSpeech{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllQuestionSpeech retrieves all QuestionSpeech matches certain condition. Returns empty list if
// no records exist
func GetAllQuestionSpeech(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(QuestionSpeech))
// 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 []QuestionSpeech
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
}
// UpdateQuestionSpeech updates QuestionSpeech by Id and returns error if
// the record to be updated doesn't exist
func UpdateQuestionSpeechById(m *QuestionSpeech) (err error) {
o := orm.NewOrm()
v := QuestionSpeech{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
}
// DeleteQuestionSpeech deletes QuestionSpeech by Id and returns error if
// the record to be deleted doesn't exist
func DeleteQuestionSpeech(id int) (err error) {
o := orm.NewOrm()
v := QuestionSpeech{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&QuestionSpeech{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type Roles struct {
Id int `orm:"column(id);auto"`
Name string `orm:"column(name);size(191)"`
GuardName string `orm:"column(guard_name);size(191)"`
CreatedAt time.Time `orm:"column(created_at);type(timestamp);null"`
UpdatedAt time.Time `orm:"column(updated_at);type(timestamp);null"`
ShowName string `orm:"column(show_name);size(191)"`
Description string `orm:"column(description);size(191);null"`
}
func (t *Roles) TableName() string {
return "roles"
}
func init() {
orm.RegisterModel(new(Roles))
}
// AddRoles insert a new Roles into database and returns
// last inserted Id on success.
func AddRoles(m *Roles) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetRolesById retrieves Roles by Id. Returns error if
// Id doesn't exist
func GetRolesById(id int) (v *Roles, err error) {
o := orm.NewOrm()
v = &Roles{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllRoles retrieves all Roles matches certain condition. Returns empty list if
// no records exist
func GetAllRoles(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(Roles))
// 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 []Roles
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
}
// UpdateRoles updates Roles by Id and returns error if
// the record to be updated doesn't exist
func UpdateRolesById(m *Roles) (err error) {
o := orm.NewOrm()
v := Roles{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
}
// DeleteRoles deletes Roles by Id and returns error if
// the record to be deleted doesn't exist
func DeleteRoles(id int) (err error) {
o := orm.NewOrm()
v := Roles{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&Roles{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import "time"
type Solution struct {
Id_RENAME int64 `orm:"column(id)" description:"方案ID"`
QuestionTitle string `orm:"column(questionTitle);size(500);null" description:"问题标题"`
Uid int64 `orm:"column(uid)" description:"方案提供者"`
CreateTime time.Time `orm:"column(createTime);type(timestamp);null" description:"方案创建时间"`
Content string `orm:"column(content);null" description:"方案内容"`
ScoreAnalyze int `orm:"column(scoreAnalyze);null" description:"分析评分(0-5对应分数)"`
ScoreSolution int `orm:"column(scoreSolution);null" description:"解决评分(0-5对应分数)"`
ScoreScheme int `orm:"column(scoreScheme);null" description:"方案评分(0-5对应分数)"`
PageView int `orm:"column(pageView);null" description:"浏览总数"`
CommentTotal int `orm:"column(commentTotal);null" description:"评论总数"`
SympathyTotal int `orm:"column(sympathyTotal);null" description:"同感总数"`
Qid int64 `orm:"column(qid);null" description:"问题ID"`
Plevel int `orm:"column(plevel);null" description:"最新评分人等级"`
Stype int `orm:"column(stype);null" description:"0备选方案 1解决方案"`
SpfUid int64 `orm:"column(spfUid)"`
UpdateTime time.Time `orm:"column(updateTime);type(timestamp);auto_now_add" description:"方案编辑更新时间"`
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"github.com/astaxie/beego/orm"
)
type SolutionImage struct {
Id int `orm:"column(id);auto" description:"方案ID"`
SolutionId int64 `orm:"column(solution_id)" description:"解决方案ID"`
Path string `orm:"column(path);size(255)" description:"图片路径"`
H int `orm:"column(h)"`
W int `orm:"column(w)"`
}
func (t *SolutionImage) TableName() string {
return "solution_image"
}
func init() {
orm.RegisterModel(new(SolutionImage))
}
// AddSolutionImage insert a new SolutionImage into database and returns
// last inserted Id on success.
func AddSolutionImage(m *SolutionImage) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetSolutionImageById retrieves SolutionImage by Id. Returns error if
// Id doesn't exist
func GetSolutionImageById(id int) (v *SolutionImage, err error) {
o := orm.NewOrm()
v = &SolutionImage{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllSolutionImage retrieves all SolutionImage matches certain condition. Returns empty list if
// no records exist
func GetAllSolutionImage(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(SolutionImage))
// 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 []SolutionImage
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
}
// UpdateSolutionImage updates SolutionImage by Id and returns error if
// the record to be updated doesn't exist
func UpdateSolutionImageById(m *SolutionImage) (err error) {
o := orm.NewOrm()
v := SolutionImage{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
}
// DeleteSolutionImage deletes SolutionImage by Id and returns error if
// the record to be deleted doesn't exist
func DeleteSolutionImage(id int) (err error) {
o := orm.NewOrm()
v := SolutionImage{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&SolutionImage{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type SolutionPartner struct {
Id int `orm:"column(id);auto"`
Uid int64 `orm:"column(uid);null" description:"参与者用户ID"`
Sid int64 `orm:"column(sid);null" description:"解决方案ID"`
ScoreSolution int `orm:"column(scoreSolution);null"`
CreateTime time.Time `orm:"column(createTime);type(timestamp);auto_now_add" description:"评分时间"`
Puid int64 `orm:"column(puid);null" description:"评分人用户ID"`
Enabled int `orm:"column(enabled);null" description:"有效1 失效0"`
Sort int `orm:"column(sort)" description:"排序字段"`
}
func (t *SolutionPartner) TableName() string {
return "solution_partner"
}
func init() {
orm.RegisterModel(new(SolutionPartner))
}
// AddSolutionPartner insert a new SolutionPartner into database and returns
// last inserted Id on success.
func AddSolutionPartner(m *SolutionPartner) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetSolutionPartnerById retrieves SolutionPartner by Id. Returns error if
// Id doesn't exist
func GetSolutionPartnerById(id int) (v *SolutionPartner, err error) {
o := orm.NewOrm()
v = &SolutionPartner{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllSolutionPartner retrieves all SolutionPartner matches certain condition. Returns empty list if
// no records exist
func GetAllSolutionPartner(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(SolutionPartner))
// 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 []SolutionPartner
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
}
// UpdateSolutionPartner updates SolutionPartner by Id and returns error if
// the record to be updated doesn't exist
func UpdateSolutionPartnerById(m *SolutionPartner) (err error) {
o := orm.NewOrm()
v := SolutionPartner{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
}
// DeleteSolutionPartner deletes SolutionPartner by Id and returns error if
// the record to be deleted doesn't exist
func DeleteSolutionPartner(id int) (err error) {
o := orm.NewOrm()
v := SolutionPartner{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&SolutionPartner{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}
package models
import (
"errors"
"fmt"
"reflect"
"strings"
"time"
"github.com/astaxie/beego/orm"
)
type SolutionScore struct {
Id int `orm:"column(id);pk"`
Uid int64 `orm:"column(uid);null" description:"评分用户ID"`
Sid int64 `orm:"column(sid);null" description:"所属的问题ID"`
ScoreAnalyze int `orm:"column(scoreAnalyze);null"`
ScoreScheme int `orm:"column(scoreScheme);null"`
ScoreSolution int `orm:"column(scoreSolution);null"`
CreateTime time.Time `orm:"column(createTime);type(timestamp);auto_now" description:"评分时间"`
}
func (t *SolutionScore) TableName() string {
return "solution_score"
}
func init() {
orm.RegisterModel(new(SolutionScore))
}
// AddSolutionScore insert a new SolutionScore into database and returns
// last inserted Id on success.
func AddSolutionScore(m *SolutionScore) (id int64, err error) {
o := orm.NewOrm()
id, err = o.Insert(m)
return
}
// GetSolutionScoreById retrieves SolutionScore by Id. Returns error if
// Id doesn't exist
func GetSolutionScoreById(id int) (v *SolutionScore, err error) {
o := orm.NewOrm()
v = &SolutionScore{Id: id}
if err = o.Read(v); err == nil {
return v, nil
}
return nil, err
}
// GetAllSolutionScore retrieves all SolutionScore matches certain condition. Returns empty list if
// no records exist
func GetAllSolutionScore(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(SolutionScore))
// 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 []SolutionScore
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
}
// UpdateSolutionScore updates SolutionScore by Id and returns error if
// the record to be updated doesn't exist
func UpdateSolutionScoreById(m *SolutionScore) (err error) {
o := orm.NewOrm()
v := SolutionScore{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
}
// DeleteSolutionScore deletes SolutionScore by Id and returns error if
// the record to be deleted doesn't exist
func DeleteSolutionScore(id int) (err error) {
o := orm.NewOrm()
v := SolutionScore{Id: id}
// ascertain id exists in the database
if err = o.Read(&v); err == nil {
var num int64
if num, err = o.Delete(&SolutionScore{Id: id}); err == nil {
fmt.Println("Number of records deleted in database:", num)
}
}
return
}