| 1234567891011121314151617181920212223242526272829303132333435363738394041424344 |
- func (m *default{{.upperStartCamelObject}}Model) FindOneBy{{.upperField}}(ctx context.Context, {{.in}}) (*{{.upperStartCamelObject}}, error) {
- {{if .withCache}}{{.cacheKey}}
- var resp {{.upperStartCamelObject}}
- err := m.QueryRowIndexCtx(ctx, &resp, {{.cacheKeyVariable}}, m.formatPrimary, func(ctx context.Context, conn sqlx.SqlConn, v any) (i any, e error) {
- query := fmt.Sprintf("SELECT %s FROM %s WHERE {{.originalField}} LIMIT 1", {{.lowerStartCamelObject}}Rows, m.table)
- if err := conn.QueryRowCtx(ctx, &resp, query, {{.lowerStartCamelField}}); err != nil {
- return nil, err
- }
- return resp.{{.upperStartCamelPrimaryKey}}, nil
- }, m.queryPrimary)
- switch err {
- case nil:
- return &resp, nil
- case sqlc.ErrNotFound:
- return nil, ErrNotFound
- default:
- return nil, err
- }
- }{{else}}var resp {{.upperStartCamelObject}}
- query := fmt.Sprintf("SELECT %s FROM %s WHERE {{.originalField}} LIMIT 1", {{.lowerStartCamelObject}}Rows, m.table )
- err := m.conn.QueryRowCtx(ctx, &resp, query, {{.lowerStartCamelField}})
- switch err {
- case nil:
- return &resp, nil
- case sqlx.ErrNotFound:
- return nil, ErrNotFound
- default:
- return nil, err
- }
- }{{end}}
- func (m *default{{.upperStartCamelObject}}Model) FindOneBy{{.upperField}}WithTx(ctx context.Context, session sqlx.Session, {{.in}}) (*{{.upperStartCamelObject}}, error) {
- var resp {{.upperStartCamelObject}}
- query := fmt.Sprintf("SELECT %s FROM %s WHERE {{.originalField}} LIMIT 1", {{.lowerStartCamelObject}}Rows, m.table)
- err := session.QueryRowCtx(ctx, &resp, query, {{.lowerStartCamelField}})
- switch err {
- case nil:
- return &resp, nil
- case sqlx.ErrNotFound:
- return nil, ErrNotFound
- default:
- return nil, err
- }
- }
|