package models import ( "LAPP_GAAS_GFrame_BACKEND/db" "LAPP_GAAS_GFrame_BACKEND/utils" "xorm.io/core" "errors" ) type Attribute struct { Finr int `json:"finr" xorm:"not null pk INT(4)"` Attrnr int `json:"attrnr" xorm:"not null pk INT(4)"` Attrname string `json:"attrname" xorm:"not null VARCHAR(30)"` Descr string `json:"descr" xorm:"not null VARCHAR(40)"` Shortcode string `json:"shortcode" xorm:"not null VARCHAR(16)"` Attrtype int `json:"attrtype" xorm:"not null INT(4)"` Attrdatatype string `json:"attrdatatype" xorm:"not null VARCHAR(1)"` Attrvaltype string `json:"attrvaltype" xorm:"not null VARCHAR(1)"` Validval string `json:"validval" xorm:"not null VARCHAR(40)"` Valpicture string `json:"valpicture" xorm:"not null VARCHAR(40)"` Picture1 string `json:"picture1" xorm:"not null VARCHAR(40)"` Picture2 string `json:"picture2" xorm:"not null VARCHAR(40)"` Isattrgrp int `json:"isattrgrp" xorm:"not null INT(4)"` Lastmodif string `json:"lastmodif" xorm:"not null VARCHAR(14)"` Lastuser string `json:"lastuser" xorm:"not null VARCHAR(20)"` Credatuz string `json:"credatuz" xorm:"not null VARCHAR(14)"` Valst []AttributeValst `json:"valst" xorm:"-"` } func (t *Attribute) TableName() string { return "attribute" } // 清除string字段的右侧空格 func (t *Attribute) Clipped() { utils.TrimStruct(t, *t) } //增 func (t *Attribute) Add() error { e := db.Eloquent.Master() countrole := new(Attribute) affw, err := e.Table("attribute").ID(core.PK{t.Finr, t.Attrnr}).Count(countrole) if err != nil { return err } if affw > 0 { return errors.New("数据已经存在!") } _, err = e.Table("attribute").Insert(t) if err != nil { return err } //批量插入 for k, _ := range t.Valst { t.Valst[k].Finr = t.Finr t.Valst[k].Attrnr = t.Attrnr t.Valst[k].Credatuz = t.Credatuz t.Valst[k].Lastuser = t.Lastuser t.Valst[k].Lastmodif = t.Lastmodif } alldata := make([]AttributeValst, 0) alldata = t.Valst _, err = e.Table("attribute_valst").Insert(&alldata) if err != nil { return err } return nil } //删 func (t *Attribute) Del() bool { e := db.Eloquent.Master() _, err := e.Where("finr = ? and attrnr = ?", t.Finr, t.Attrnr).Delete(&Attribute{}) if err != nil { return false } countrole := new(AttributeValst) affw, _ := e.Table("attribute_valst").Where("finr = ? and attrnr = ?", t.Finr, t.Attrnr).Count(countrole) if affw > 0 { _, err = e.Where("finr = ? and attrnr = ?", t.Finr, t.Attrnr).Delete(&AttributeValst{}) if err != nil { return false } } return true } //改 func (t *Attribute) Update() bool { e := db.Eloquent.Master() _, err := e.ID(core.PK{t.Finr, t.Attrnr}).Update(t) if err != nil { return false } //批量删除 _, err = e.Table("attribute_valst").Where("finr = ? and attrnr = ?", t.Finr, t.Attrnr).Delete(&AttributeValst{}) if err != nil { return false } //批量插入 for k, _ := range t.Valst { t.Valst[k].Finr = t.Finr t.Valst[k].Attrnr = t.Attrnr t.Valst[k].Credatuz = t.Credatuz t.Valst[k].Lastuser = t.Lastuser t.Valst[k].Lastmodif = t.Lastmodif } //批量插入 alldata := make([]AttributeValst, 0) alldata = t.Valst _, err = e.Table("attribute_valst").Insert(&alldata) if err != nil { return false } return true } //查 func (t *Attribute) SelectOne() (Attribute, error) { e := db.Eloquent.Master() var data Attribute _, err := e.ID(core.PK{t.Finr, t.Attrnr}).Get(&data) if err != nil { return data, err } data.Clipped() var datalist []AttributeValst err = e.Where("finr = ? and attrnr = ?", t.Finr, t.Attrnr).Find(&datalist) if err != nil { return data, err } data.Valst = datalist return data, nil } //分页 func (t *Attribute) GetPage(pageSize int, pageIndex int) ([]Attribute, int, error) { data := make([]Attribute, 0) e := db.Eloquent.Master() table := e.Table("attribute").Where("finr = ? ", t.Finr) where := "where finr = " + "'" + utils.ValueToString(t.Finr, "") + "'" if t.Attrnr > 0 { table = table.And("attrnr = ?", t.Attrnr) where += " and attrnr = " + "'" + utils.ValueToString(t.Attrnr, "") + "'" } Offset := (pageIndex - 1) * pageSize err := e.SQL("SELECT TOP " + utils.ValueToString(pageSize, "") + " attribute.* FROM attribute " + where + " AND (convert(varchar(10),finr)+convert(varchar(40),attrnr) NOT IN (SELECT TOP " + utils.ValueToString(Offset, "") + " convert(varchar(10),finr)+convert(varchar(40),attrnr) FROM attribute " + where + " ORDER BY credatuz DESC)) ORDER BY credatuz DESC").Find(&data) pcount := new(Attribute) count, err := table.Count(pcount) if err != nil { return nil, 0, err } return data, int(count), nil }