You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

sctenantinfomodel_gen.go 3.7 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. // Code generated by goctl. DO NOT EDIT.
  2. package models
  3. import (
  4. "context"
  5. "database/sql"
  6. "fmt"
  7. "github.com/zeromicro/go-zero/core/stores/builder"
  8. "github.com/zeromicro/go-zero/core/stores/cache"
  9. "github.com/zeromicro/go-zero/core/stores/sqlc"
  10. "github.com/zeromicro/go-zero/core/stores/sqlx"
  11. "github.com/zeromicro/go-zero/core/stringx"
  12. "strings"
  13. )
  14. var (
  15. scTenantInfoFieldNames = builder.RawFieldNames(&ScTenantInfo{})
  16. scTenantInfoRows = strings.Join(scTenantInfoFieldNames, ",")
  17. scTenantInfoRowsExpectAutoSet = strings.Join(stringx.Remove(scTenantInfoFieldNames, "`create_at`", "`create_time`", "`created_at`", "`update_at`", "`update_time`", "`updated_at`"), ",")
  18. scTenantInfoRowsWithPlaceHolder = strings.Join(stringx.Remove(scTenantInfoFieldNames, "`id`", "`create_at`", "`create_time`", "`created_at`", "`update_at`", "`update_time`", "`updated_at`"), "=?,") + "=?"
  19. cachePcmScTenantInfoIdPrefix = "cache:pcm:scTenantInfo:id:"
  20. )
  21. type (
  22. scTenantInfoModel interface {
  23. Insert(ctx context.Context, data *ScTenantInfo) (sql.Result, error)
  24. FindOne(ctx context.Context, id int64) (*ScTenantInfo, error)
  25. Update(ctx context.Context, data *ScTenantInfo) error
  26. Delete(ctx context.Context, id int64) error
  27. }
  28. defaultScTenantInfoModel struct {
  29. sqlc.CachedConn
  30. table string
  31. }
  32. ScTenantInfo struct {
  33. Id int64 `db:"id"` // id
  34. TenantName string `db:"tenant_name"` // 租户名称
  35. TenantDesc string `db:"tenant_desc"` // 描述信息
  36. Clusters string `db:"clusters"` // 集群名称,用","分割
  37. Type int64 `db:"type"` // 租户所属(0数算,1超算,2智算)
  38. DeletedFlag int64 `db:"deleted_flag"` // 是否删除
  39. }
  40. )
  41. func newScTenantInfoModel(conn sqlx.SqlConn, c cache.CacheConf, opts ...cache.Option) *defaultScTenantInfoModel {
  42. return &defaultScTenantInfoModel{
  43. CachedConn: sqlc.NewConn(conn, c, opts...),
  44. table: "`sc_tenant_info`",
  45. }
  46. }
  47. func (m *defaultScTenantInfoModel) withSession(session sqlx.Session) *defaultScTenantInfoModel {
  48. return &defaultScTenantInfoModel{
  49. CachedConn: m.CachedConn.WithSession(session),
  50. table: "`sc_tenant_info`",
  51. }
  52. }
  53. func (m *defaultScTenantInfoModel) Delete(ctx context.Context, id int64) error {
  54. pcmScTenantInfoIdKey := fmt.Sprintf("%s%v", cachePcmScTenantInfoIdPrefix, id)
  55. _, err := m.ExecCtx(ctx, func(ctx context.Context, conn sqlx.SqlConn) (result sql.Result, err error) {
  56. query := fmt.Sprintf("delete from %s where `id` = ?", m.table)
  57. return conn.ExecCtx(ctx, query, id)
  58. }, pcmScTenantInfoIdKey)
  59. return err
  60. }
  61. func (m *defaultScTenantInfoModel) FindOne(ctx context.Context, id int64) (*ScTenantInfo, error) {
  62. pcmScTenantInfoIdKey := fmt.Sprintf("%s%v", cachePcmScTenantInfoIdPrefix, id)
  63. var resp ScTenantInfo
  64. err := m.QueryRowCtx(ctx, &resp, pcmScTenantInfoIdKey, func(ctx context.Context, conn sqlx.SqlConn, v any) error {
  65. query := fmt.Sprintf("select %s from %s where `id` = ? limit 1", scTenantInfoRows, m.table)
  66. return conn.QueryRowCtx(ctx, v, query, id)
  67. })
  68. switch err {
  69. case nil:
  70. return &resp, nil
  71. case sqlc.ErrNotFound:
  72. return nil, ErrNotFound
  73. default:
  74. return nil, err
  75. }
  76. }
  77. func (m *defaultScTenantInfoModel) formatPrimary(primary any) string {
  78. return fmt.Sprintf("%s%v", cachePcmScTenantInfoIdPrefix, primary)
  79. }
  80. func (m *defaultScTenantInfoModel) queryPrimary(ctx context.Context, conn sqlx.SqlConn, v, primary any) error {
  81. query := fmt.Sprintf("select %s from %s where `id` = ? limit 1", scTenantInfoRows, m.table)
  82. return conn.QueryRowCtx(ctx, v, query, primary)
  83. }
  84. func (m *defaultScTenantInfoModel) tableName() string {
  85. return m.table
  86. }

PCM is positioned as Software stack over Cloud, aiming to build the standards and ecology of heterogeneous cloud collaboration for JCC in a non intrusive and autonomous peer-to-peer manner.