首页 > 其他分享 >go gorm StructField动态生成结构体查询单条表记录

go gorm StructField动态生成结构体查询单条表记录

时间:2024-10-13 10:47:21浏览次数:12  
标签:err StructField self reflect var dbc TypeOf go gorm

func Test014_TakeTableFields(t *testing.T) {

    var dbRequest = Default().SetPageSize(2)
    dbRequest.TableName = "sys_dept"
    dbRequest.FieldsName = "dept_id,dept_name"
    var result = dbRequest.GeneralTakeTable()
    golog.Info(result)

}

INFO[2024-10-1013 10:48:23]C:/Users/leijmdas/go/pkg/mod/gitee.com/leijmdas/gobase/goconfig@v0.0.0-20241013021345-c1204e9c955d/common/golog/go_logger.go:12 gitee.com/leijmdas/gobase/goconfig/common/golog.Info() {
     "code": 200,
     "msg": "成功",
     "page_size": 2,
     "current": 1,
     "total": 10,
     "data": {
          "DeptId": 100,
          "DeptName": "若依科技"
     },
     "data_agg": null,
     "data_highlight": null,
     "hosturl": ""

func (self *PagedbRequest) GeneralTakeTable() *page.PageResult {
    var metadataFactroy = service.NewMetadataFactroy()
    var metadata = metadataFactroy.FindMetadata(self.TableName)
    if !metadata.TableExist {
       return page.ResultFailedPageResultErr(errors.New("table not exist"))
    }
    var dbentity = self.CreateDbTableStru(metadata)

    return self.PageRequest.TakeTable(self.TableName, dbentity.Addr().Interface())
}
unc (self *PagedbRequest) CreateDbTableStru(meta *metadata.MetadataTable) reflect.Value {
    // logrus.Info("CreateDbTableStru meta=", meta.ToPrettyString())
    var metaColService = service.NewMetadataFactroy()
    dbFields := []reflect.StructField{}

    for _, col := range meta.Columns {
       //logrus.Info("CreateDbTableStru col=", col.ToPrettyString())
       var colType = metaColService.FindGoType(col.DataType)
       var ColTyp8 = reflect.TypeOf(int8(0))

       var ct = func(colType string) *reflect.Type {
          var ColTyp = reflect.TypeOf(int8(0))
          switch colType {
          case "float64":
             ColTyp = reflect.TypeOf(float64(0))
          case "int64":
             ColTyp = reflect.TypeOf(int64(0))
          case "int32":
             ColTyp = reflect.TypeOf(int64(0))
          case "string":
             ColTyp = reflect.TypeOf("")
          case "bool":
             ColTyp = reflect.TypeOf(true)
          case "byte":
             ColTyp = reflect.TypeOf(byte(0))
          case "[]byte":
             ColTyp = reflect.TypeOf([]byte{})

          case "time.Time":
             ColTyp = reflect.TypeOf(time.Now())

          }
          return &ColTyp
       }(colType)
       if ColTyp8 != *ct {
          var colField = reflect.StructField{
             Name: stringutils.Case2Camel(col.ColumnName),
             Type: *ct,
          }
          if self.IfExistField(col.ColumnName) {
             //colField.Tag = reflect.StructTag(fmt.Sprintf("json:\"%s\"", col.ColumnName))

             dbFields = append(dbFields, colField)
          }
       }
    }

    dbtableType := reflect.StructOf(dbFields)
    dbentity := reflect.New(dbtableType).Elem()
    return dbentity
}
func (self *PageRequest) TakeTable(table string, model interface{}) *PageResult {

    ///fileName := table + "_pagerequest.json"
    self.InitPage()

    count, err := self.CountTable(table)
    if err != nil {
       golog.Error(err)
       return ResultFailedPageResultErr(err)
    }
    if count > 0 {
       err = self.FindTakeTable(table, model)
       if err != nil {
          logrus.Error(err)
          return NewPageResultError(err.Error())
       }
    }
    var result = PageResultOf(self)
    result.Total = count
    result.Data = model

    return result
}
func (self *PageRequest) FindTakeTable(table string, result interface{}) error {

    dbc := self.GetDB().Table(table) //.Select("id,name")
    dbc = self.BuildWhere(dbc)
    dbc = self.Order(dbc)
    dbc = self.SetLimit(dbc)
    dbc = dbc.Take(result)

    return dbc.Error
}
func (self *PageRequest) CountTable(table string) (int, error) {
    dbc := self.GetDB().Table(table)
    dbc = self.BuildWhere(dbc).Offset(0).Limit(1)
    var count int
    if err := dbc.Count(&count).Error; err != nil {
       logrus.Error(err)
       return 0, err
    }

    logrus.Info("\ncount=", count)
    return count, nil

}

标签:err,StructField,self,reflect,var,dbc,TypeOf,go,gorm
From: https://blog.csdn.net/leijmdas/article/details/142895172

相关文章

  • go gorm StructField动态生成结构体查询多条表记录
    water/gowebfuncTest013_GeneralScanTable(t*testing.T){vardbRequest=Default().SetPageSize(3)dbRequest.TableName="sys_dept"dbRequest.FieldsName="dept_id,dept_name"//dbRequest.SetQueryAll(true)varresult=......
  • 基于django+vue+Vue火车票订票系统【开题报告+程序+论文】-计算机毕设
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景随着信息技术的飞速发展和人民生活水平的不断提高,铁路出行已成为人们日常生活中不可或缺的交通方式之一。传统的火车票购买方式,如排队购票......
  • 基于django+vue+Vue花店销售系统【开题报告+程序+论文】-计算机毕设
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景随着人们生活水平的提高和消费观念的转变,鲜花作为一种传递情感、美化生活的特殊商品,其市场需求日益旺盛。传统的花店销售模式往往依赖于线......
  • 基于django+vue+Vue湖南特色农产品销售系统【开题报告+程序+论文】-计算机毕设
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景湖南,作为中国的一个农业大省,拥有丰富的特色农产品资源,如湘莲、临武鸭、安化黑茶等,这些农产品不仅品质上乘,而且承载着湖南深厚的文化底蕴。......
  • 基于django+vue+Vue红枫超市会员管理系统【开题报告+程序+论文】-计算机毕设
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景随着市场经济的快速发展和消费者需求的多样化,超市作为零售业的重要组成部分,面临着日益激烈的竞争。红枫超市作为一家在当地具有良好口碑的......