123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511 |
- package mgo
- import (
- "context"
- "errors"
- "eta/eta_mobile/utils"
- "fmt"
- "github.com/qiniu/qmgo"
- "go.mongodb.org/mongo-driver/bson"
- "go.mongodb.org/mongo-driver/bson/primitive"
- "time"
- )
- type EdbDataBusiness struct {
- ID primitive.ObjectID `json:"_id" bson:"_id,omitempty" `
- EdbInfoId int `json:"edb_info_id" bson:"edb_info_id"`
- EdbCode string `json:"edb_code" bson:"edb_code"`
- DataTime time.Time `json:"data_time" bson:"data_time"`
- Value float64 `json:"value" bson:"value"`
- CreateTime time.Time `json:"create_time" bson:"create_time"`
- ModifyTime time.Time `json:"modify_time" bson:"modify_time"`
- DataTimestamp int64 `json:"data_timestamp" bson:"data_timestamp"`
- }
- func (m *EdbDataBusiness) CollectionName() string {
- return "edb_data_business"
- }
- func (m *EdbDataBusiness) DataBaseName() string {
- return utils.MgoDataDbName
- }
- func (m *EdbDataBusiness) GetCollection() *qmgo.Collection {
- db := utils.MgoDataCli.Database(m.DataBaseName())
- return db.Collection(m.CollectionName())
- }
- func (m *EdbDataBusiness) GetItem(whereParams interface{}) (item *EdbDataBusiness, err error) {
- if utils.MgoDataCli == nil {
- err = errors.New("mongodb连接失败")
- return
- }
- db := utils.MgoDataCli.Database(m.DataBaseName())
- coll := db.Collection(m.CollectionName())
- return m.GetItemByColl(coll, whereParams)
- }
- func (m *EdbDataBusiness) GetItemByColl(coll *qmgo.Collection, whereParams interface{}) (item *EdbDataBusiness, err error) {
- ctx := context.TODO()
- if err != nil {
- fmt.Println("MgoGetColl Err:", err.Error())
- return
- }
- err = coll.Find(ctx, whereParams).One(&item)
- if err != nil {
- return
- }
- item.DataTime = item.DataTime.In(time.Local)
- item.CreateTime = item.CreateTime.In(time.Local)
- item.ModifyTime = item.ModifyTime.In(time.Local)
- return
- }
- func (m *EdbDataBusiness) GetAllDataList(whereParams interface{}, sort []string) (result []*EdbDataBusiness, err error) {
- if utils.MgoDataCli == nil {
- err = errors.New("mongodb连接失败")
- return
- }
- db := utils.MgoDataCli.Database(m.DataBaseName())
- coll := db.Collection(m.CollectionName())
- ctx := context.TODO()
- if err != nil {
- fmt.Println("MgoGetColl Err:", err.Error())
- return
- }
- err = coll.Find(ctx, whereParams).Sort(sort...).All(&result)
- if err != nil {
- return
- }
- for _, v := range result {
- v.DataTime = v.DataTime.In(time.Local)
- v.CreateTime = v.CreateTime.In(time.Local)
- v.ModifyTime = v.ModifyTime.In(time.Local)
- }
- return
- }
- func (m *EdbDataBusiness) GetLimitDataList(whereParams interface{}, size int64, sort []string) (result []*EdbDataBusiness, err error) {
- if utils.MgoDataCli == nil {
- err = errors.New("mongodb连接失败")
- return
- }
- db := utils.MgoDataCli.Database(m.DataBaseName())
- coll := db.Collection(m.CollectionName())
- ctx := context.TODO()
- if err != nil {
- fmt.Println("MgoGetColl Err:", err.Error())
- return
- }
- err = coll.Find(ctx, whereParams).Sort(sort...).Limit(size).All(&result)
- if err != nil {
- return
- }
- for _, v := range result {
- v.DataTime = v.DataTime.In(time.Local)
- v.CreateTime = v.CreateTime.In(time.Local)
- v.ModifyTime = v.ModifyTime.In(time.Local)
- }
- return
- }
- func (m *EdbDataBusiness) GetPageDataList(whereParams interface{}, startSize, size int64, sort []string) (result []*EdbDataBusiness, err error) {
- if utils.MgoDataCli == nil {
- err = errors.New("mongodb连接失败")
- return
- }
- db := utils.MgoDataCli.Database(m.DataBaseName())
- coll := db.Collection(m.CollectionName())
- ctx := context.TODO()
- if err != nil {
- fmt.Println("MgoGetColl Err:", err.Error())
- return
- }
- err = coll.Find(ctx, whereParams).Sort(sort...).Skip(startSize).Limit(size).All(&result)
- if err != nil {
- return
- }
- for _, v := range result {
- v.DataTime = v.DataTime.In(time.Local)
- v.CreateTime = v.CreateTime.In(time.Local)
- v.ModifyTime = v.ModifyTime.In(time.Local)
- }
- return
- }
- func (m *EdbDataBusiness) GetCountDataList(whereParams interface{}) (count int64, err error) {
- if utils.MgoDataCli == nil {
- err = errors.New("mongodb连接失败")
- return
- }
- db := utils.MgoDataCli.Database(m.DataBaseName())
- coll := db.Collection(m.CollectionName())
- ctx := context.TODO()
- if err != nil {
- fmt.Println("MgoGetColl Err:", err.Error())
- return
- }
- count, err = coll.Find(ctx, whereParams).Count()
- return
- }
- func (m *EdbDataBusiness) InsertDataByColl(coll *qmgo.Collection, addData interface{}) (err error) {
- ctx := context.TODO()
- _, err = coll.InsertOne(ctx, addData)
- if err != nil {
- fmt.Println("InsertDataByColl:Err:" + err.Error())
- return
- }
- return
- }
- func (m *EdbDataBusiness) BatchInsertData(bulk int, dataList []interface{}) (err error) {
- db := utils.MgoDataCli.Database(m.DataBaseName())
- coll := db.Collection(m.CollectionName())
- return m.BatchInsertDataByColl(coll, bulk, dataList)
- }
- func (m *EdbDataBusiness) BatchInsertDataByColl(coll *qmgo.Collection, bulk int, dataList []interface{}) (err error) {
- ctx := context.TODO()
- dataNum := len(dataList)
- if dataNum <= 0 {
- return
- }
-
- if bulk <= 0 || dataNum <= bulk {
- _, err = coll.InsertMany(ctx, dataList)
- if err != nil {
- fmt.Println("BatchInsertData:Err:" + err.Error())
- return
- }
- return
- }
-
- i := 0
- tmpAddDataList := make([]interface{}, 0)
- for _, v := range dataList {
- tmpAddDataList = append(tmpAddDataList, v)
- i++
- if i >= bulk {
- _, err = coll.InsertMany(ctx, tmpAddDataList)
- if err != nil {
- fmt.Println("BatchInsertData:Err:" + err.Error())
- return
- }
- i = 0
- tmpAddDataList = make([]interface{}, 0)
- }
- }
- if len(tmpAddDataList) > 0 {
- _, err = coll.InsertMany(ctx, tmpAddDataList)
- if err != nil {
- fmt.Println("BatchInsertData:Err:" + err.Error())
- return
- }
- }
- return
- }
- func (m *EdbDataBusiness) UpdateData(whereParams, updateParams interface{}) (err error) {
- db := utils.MgoDataCli.Database(m.DataBaseName())
- coll := db.Collection(m.CollectionName())
- return m.UpdateDataByColl(coll, whereParams, updateParams)
- }
- func (m *EdbDataBusiness) UpdateDataByColl(coll *qmgo.Collection, whereParams, updateParams interface{}) (err error) {
- ctx := context.TODO()
- err = coll.UpdateOne(ctx, whereParams, updateParams)
- if err != nil {
- fmt.Println("UpdateDataByColl:Err:" + err.Error())
- return
- }
- return
- }
- func (m *EdbDataBusiness) RemoveMany(whereParams interface{}) (err error) {
- db := utils.MgoDataCli.Database(m.DataBaseName())
- coll := db.Collection(m.CollectionName())
- return m.RemoveManyByColl(coll, whereParams)
- }
- func (m *EdbDataBusiness) RemoveManyByColl(coll *qmgo.Collection, whereParams interface{}) (err error) {
- ctx := context.TODO()
- _, err = coll.RemoveAll(ctx, whereParams)
- if err != nil {
- fmt.Println("RemoveManyByColl:Err:" + err.Error())
- return
- }
- return
- }
- func (m *EdbDataBusiness) HandleData(addDataList, updateDataList []EdbDataBusiness) (result interface{}, err error) {
- ctx := context.TODO()
- callback := func(sessCtx context.Context) (interface{}, error) {
-
- db := utils.MgoDataCli.Database(m.DataBaseName())
- coll := db.Collection(m.CollectionName())
-
- if len(addDataList) > 0 {
- _, err = coll.InsertMany(sessCtx, addDataList)
- if err != nil {
- return nil, err
- }
- }
-
- if len(updateDataList) > 0 {
- for _, v := range updateDataList {
- err = coll.UpdateOne(ctx, bson.M{"_id": v.ID}, bson.M{"$set": bson.M{"value": v.Value, "modify_time": v.ModifyTime}})
- if err != nil {
- fmt.Println("BatchInsertData:Err:" + err.Error())
- return nil, err
- }
- }
- }
- return nil, nil
- }
- result, err = utils.MgoDataCli.DoTransaction(ctx, callback)
- return
- }
- type EdbInfoMaxAndMinInfo struct {
- MinDate time.Time `description:"最小日期" bson:"min_date"`
- MaxDate time.Time `description:"最大日期" bson:"max_date"`
- MinValue float64 `description:"最小值" bson:"min_value"`
- MaxValue float64 `description:"最大值" bson:"max_value"`
- LatestValue float64 `description:"最新值" bson:"latest_value"`
- LatestDate time.Time `description:"实际数据最新日期" bson:"latest_date"`
- EndValue float64 `description:"最新值" bson:"end_value"`
- }
- func (m *EdbDataBusiness) GetEdbInfoMaxAndMinInfo(whereParams interface{}) (result EdbInfoMaxAndMinInfo, err error) {
- if utils.MgoDataCli == nil {
- err = errors.New("mongodb连接失败")
- return
- }
- db := utils.MgoDataCli.Database(m.DataBaseName())
- coll := db.Collection(m.CollectionName())
- ctx := context.TODO()
- if err != nil {
- fmt.Println("MgoGetColl Err:", err.Error())
- return
- }
- err = coll.Aggregate(ctx, whereParams).One(&result)
- if err != nil {
- return
- }
- result.MinDate = result.MinDate.In(time.Local)
- result.MaxDate = result.MaxDate.In(time.Local)
- result.LatestDate = result.LatestDate.In(time.Local)
- return
- }
- type LatestValue struct {
- Value float64 `description:"值" bson:"value"`
- }
- func (m *EdbDataBusiness) GetLatestValue(whereParams, selectParam interface{}) (latestValue LatestValue, err error) {
- if utils.MgoDataCli == nil {
- err = errors.New("mongodb连接失败")
- return
- }
- db := utils.MgoDataCli.Database(m.DataBaseName())
- coll := db.Collection(m.CollectionName())
- ctx := context.TODO()
- if err != nil {
- fmt.Println("MgoGetColl Err:", err.Error())
- return
- }
-
-
- err = coll.Find(ctx, whereParams).Select(selectParam).One(&latestValue)
- return
- }
|