find.go 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. package template
  2. const (
  3. // FindOne defines find row by id.
  4. FindOne = `
  5. func (m *default{{.upperStartCamelObject}}Model) FindOne(ctx context.Context, {{.lowerStartCamelPrimaryKey}} {{.dataType}}) (*{{.upperStartCamelObject}}, error) {
  6. {{if .withCache}}{{.cacheKey}}
  7. var resp {{.upperStartCamelObject}}
  8. err := m.QueryRowCtx(ctx, &resp, {{.cacheKeyVariable}}, func(ctx context.Context, conn sqlx.SqlConn, v interface{}) error {
  9. query := fmt.Sprintf("select %s from %s where {{.originalPrimaryKey}} = {{if .postgreSql}}$1{{else}}?{{end}} limit 1", {{.lowerStartCamelObject}}Rows, m.table)
  10. return conn.QueryRowCtx(ctx, v, query, {{.lowerStartCamelPrimaryKey}})
  11. })
  12. switch err {
  13. case nil:
  14. return &resp, nil
  15. case sqlc.ErrNotFound:
  16. return nil, ErrNotFound
  17. default:
  18. return nil, err
  19. }{{else}}query := fmt.Sprintf("select %s from %s where {{.originalPrimaryKey}} = {{if .postgreSql}}$1{{else}}?{{end}} limit 1", {{.lowerStartCamelObject}}Rows, m.table)
  20. var resp {{.upperStartCamelObject}}
  21. err := m.conn.QueryRowCtx(ctx, &resp, query, {{.lowerStartCamelPrimaryKey}})
  22. switch err {
  23. case nil:
  24. return &resp, nil
  25. case sqlc.ErrNotFound:
  26. return nil, ErrNotFound
  27. default:
  28. return nil, err
  29. }{{end}}
  30. }
  31. `
  32. // FindOneByField defines find row by field.
  33. FindOneByField = `
  34. func (m *default{{.upperStartCamelObject}}Model) FindOneBy{{.upperField}}(ctx context.Context, {{.in}}) (*{{.upperStartCamelObject}}, error) {
  35. {{if .withCache}}{{.cacheKey}}
  36. var resp {{.upperStartCamelObject}}
  37. err := m.QueryRowIndexCtx(ctx, &resp, {{.cacheKeyVariable}}, m.formatPrimary, func(ctx context.Context, conn sqlx.SqlConn, v interface{}) (i interface{}, e error) {
  38. query := fmt.Sprintf("select %s from %s where {{.originalField}} limit 1", {{.lowerStartCamelObject}}Rows, m.table)
  39. if err := conn.QueryRowCtx(ctx, &resp, query, {{.lowerStartCamelField}}); err != nil {
  40. return nil, err
  41. }
  42. return resp.{{.upperStartCamelPrimaryKey}}, nil
  43. }, m.queryPrimary)
  44. switch err {
  45. case nil:
  46. return &resp, nil
  47. case sqlc.ErrNotFound:
  48. return nil, ErrNotFound
  49. default:
  50. return nil, err
  51. }
  52. }{{else}}var resp {{.upperStartCamelObject}}
  53. query := fmt.Sprintf("select %s from %s where {{.originalField}} limit 1", {{.lowerStartCamelObject}}Rows, m.table )
  54. err := m.conn.QueryRowCtx(ctx, &resp, query, {{.lowerStartCamelField}})
  55. switch err {
  56. case nil:
  57. return &resp, nil
  58. case sqlc.ErrNotFound:
  59. return nil, ErrNotFound
  60. default:
  61. return nil, err
  62. }
  63. }{{end}}
  64. `
  65. // FindOneByFieldExtraMethod defines find row by field with extras.
  66. FindOneByFieldExtraMethod = `
  67. func (m *default{{.upperStartCamelObject}}Model) formatPrimary(primary interface{}) string {
  68. return fmt.Sprintf("%s%v", {{.primaryKeyLeft}}, primary)
  69. }
  70. func (m *default{{.upperStartCamelObject}}Model) queryPrimary(ctx context.Context, conn sqlx.SqlConn, v, primary interface{}) error {
  71. query := fmt.Sprintf("select %s from %s where {{.originalPrimaryField}} = {{if .postgreSql}}$1{{else}}?{{end}} limit 1", {{.lowerStartCamelObject}}Rows, m.table )
  72. return conn.QueryRowCtx(ctx, v, query, primary)
  73. }
  74. `
  75. // FindOneMethod defines find row method.
  76. FindOneMethod = `FindOne(ctx context.Context, {{.lowerStartCamelPrimaryKey}} {{.dataType}}) (*{{.upperStartCamelObject}}, error)`
  77. // FindOneByFieldMethod defines find row by field method.
  78. FindOneByFieldMethod = `FindOneBy{{.upperField}}(ctx context.Context, {{.in}}) (*{{.upperStartCamelObject}}, error) `
  79. )