find-one-by-field.tpl 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. func (m *default{{.upperStartCamelObject}}Model) FindOneBy{{.upperField}}(ctx context.Context, {{.in}}) (*{{.upperStartCamelObject}}, error) {
  2. {{if .withCache}}{{.cacheKey}}
  3. var resp {{.upperStartCamelObject}}
  4. err := m.QueryRowIndexCtx(ctx, &resp, {{.cacheKeyVariable}}, m.formatPrimary, func(ctx context.Context, conn sqlx.SqlConn, v any) (i any, e error) {
  5. query := fmt.Sprintf("SELECT %s FROM %s WHERE {{.originalField}} LIMIT 1", {{.lowerStartCamelObject}}Rows, m.table)
  6. if err := conn.QueryRowCtx(ctx, &resp, query, {{.lowerStartCamelField}}); err != nil {
  7. return nil, err
  8. }
  9. return resp.{{.upperStartCamelPrimaryKey}}, nil
  10. }, m.queryPrimary)
  11. switch err {
  12. case nil:
  13. return &resp, nil
  14. case sqlc.ErrNotFound:
  15. return nil, ErrNotFound
  16. default:
  17. return nil, err
  18. }
  19. }{{else}}var resp {{.upperStartCamelObject}}
  20. query := fmt.Sprintf("SELECT %s FROM %s WHERE {{.originalField}} LIMIT 1", {{.lowerStartCamelObject}}Rows, m.table )
  21. err := m.conn.QueryRowCtx(ctx, &resp, query, {{.lowerStartCamelField}})
  22. switch err {
  23. case nil:
  24. return &resp, nil
  25. case sqlx.ErrNotFound:
  26. return nil, ErrNotFound
  27. default:
  28. return nil, err
  29. }
  30. }{{end}}
  31. func (m *default{{.upperStartCamelObject}}Model) FindOneBy{{.upperField}}WithTx(ctx context.Context, session sqlx.Session, {{.in}}) (*{{.upperStartCamelObject}}, error) {
  32. var resp {{.upperStartCamelObject}}
  33. query := fmt.Sprintf("SELECT %s FROM %s WHERE {{.originalField}} LIMIT 1", {{.lowerStartCamelObject}}Rows, m.table)
  34. err := session.QueryRowCtx(ctx, &resp, query, {{.lowerStartCamelField}})
  35. switch err {
  36. case nil:
  37. return &resp, nil
  38. case sqlx.ErrNotFound:
  39. return nil, ErrNotFound
  40. default:
  41. return nil, err
  42. }
  43. }