findonebyfield.go 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. package gen
  2. import (
  3. "fmt"
  4. "strings"
  5. "github.com/tal-tech/go-zero/tools/goctl/model/sql/template"
  6. "github.com/tal-tech/go-zero/tools/goctl/util"
  7. "github.com/tal-tech/go-zero/tools/goctl/util/stringx"
  8. )
  9. type findOneCode struct {
  10. findOneMethod string
  11. findOneInterfaceMethod string
  12. cacheExtra string
  13. }
  14. func genFindOneByField(table Table, withCache, postgreSql bool) (*findOneCode, error) {
  15. text, err := util.LoadTemplate(category, findOneByFieldTemplateFile, template.FindOneByField)
  16. if err != nil {
  17. return nil, err
  18. }
  19. t := util.With("findOneByField").Parse(text)
  20. var list []string
  21. camelTableName := table.Name.ToCamel()
  22. for _, key := range table.UniqueCacheKey {
  23. in, paramJoinString, originalFieldString := convertJoin(key, postgreSql)
  24. output, err := t.Execute(map[string]interface{}{
  25. "upperStartCamelObject": camelTableName,
  26. "upperField": key.FieldNameJoin.Camel().With("").Source(),
  27. "in": in,
  28. "withCache": withCache,
  29. "cacheKey": key.KeyExpression,
  30. "cacheKeyVariable": key.KeyLeft,
  31. "lowerStartCamelObject": stringx.From(camelTableName).Untitle(),
  32. "lowerStartCamelField": paramJoinString,
  33. "upperStartCamelPrimaryKey": table.PrimaryKey.Name.ToCamel(),
  34. "originalField": originalFieldString,
  35. "postgreSql": postgreSql,
  36. })
  37. if err != nil {
  38. return nil, err
  39. }
  40. list = append(list, output.String())
  41. }
  42. text, err = util.LoadTemplate(category, findOneByFieldMethodTemplateFile, template.FindOneByFieldMethod)
  43. if err != nil {
  44. return nil, err
  45. }
  46. t = util.With("findOneByFieldMethod").Parse(text)
  47. var listMethod []string
  48. for _, key := range table.UniqueCacheKey {
  49. var inJoin, paramJoin Join
  50. for _, f := range key.Fields {
  51. param := stringx.From(f.Name.ToCamel()).Untitle()
  52. inJoin = append(inJoin, fmt.Sprintf("%s %s", param, f.DataType))
  53. paramJoin = append(paramJoin, param)
  54. }
  55. var in string
  56. if len(inJoin) > 0 {
  57. in = inJoin.With(", ").Source()
  58. }
  59. output, err := t.Execute(map[string]interface{}{
  60. "upperStartCamelObject": camelTableName,
  61. "upperField": key.FieldNameJoin.Camel().With("").Source(),
  62. "in": in,
  63. })
  64. if err != nil {
  65. return nil, err
  66. }
  67. listMethod = append(listMethod, output.String())
  68. }
  69. if withCache {
  70. text, err := util.LoadTemplate(category, findOneByFieldExtraMethodTemplateFile, template.FindOneByFieldExtraMethod)
  71. if err != nil {
  72. return nil, err
  73. }
  74. out, err := util.With("findOneByFieldExtraMethod").Parse(text).Execute(map[string]interface{}{
  75. "upperStartCamelObject": camelTableName,
  76. "primaryKeyLeft": table.PrimaryCacheKey.VarLeft,
  77. "lowerStartCamelObject": stringx.From(camelTableName).Untitle(),
  78. "originalPrimaryField": wrapWithRawString(table.PrimaryKey.Name.Source(), postgreSql),
  79. "postgreSql": postgreSql,
  80. })
  81. if err != nil {
  82. return nil, err
  83. }
  84. return &findOneCode{
  85. findOneMethod: strings.Join(list, util.NL),
  86. findOneInterfaceMethod: strings.Join(listMethod, util.NL),
  87. cacheExtra: out.String(),
  88. }, nil
  89. }
  90. return &findOneCode{
  91. findOneMethod: strings.Join(list, util.NL),
  92. findOneInterfaceMethod: strings.Join(listMethod, util.NL),
  93. }, nil
  94. }
  95. func convertJoin(key Key, postgreSql bool) (in, paramJoinString, originalFieldString string) {
  96. var inJoin, paramJoin, argJoin Join
  97. for index, f := range key.Fields {
  98. param := stringx.From(f.Name.ToCamel()).Untitle()
  99. inJoin = append(inJoin, fmt.Sprintf("%s %s", param, f.DataType))
  100. paramJoin = append(paramJoin, param)
  101. if postgreSql {
  102. argJoin = append(argJoin, fmt.Sprintf("%s = $%d", wrapWithRawString(f.Name.Source(), postgreSql), index+1))
  103. } else {
  104. argJoin = append(argJoin, fmt.Sprintf("%s = ?", wrapWithRawString(f.Name.Source(), postgreSql)))
  105. }
  106. }
  107. if len(inJoin) > 0 {
  108. in = inJoin.With(", ").Source()
  109. }
  110. if len(paramJoin) > 0 {
  111. paramJoinString = paramJoin.With(",").Source()
  112. }
  113. if len(argJoin) > 0 {
  114. originalFieldString = argJoin.With(" and ").Source()
  115. }
  116. return in, paramJoinString, originalFieldString
  117. }