mirror of
https://github.com/ent/ent.git
synced 2026-05-24 09:31:56 +03:00
134 lines
4.5 KiB
Cheetah
134 lines
4.5 KiB
Cheetah
{{/*
|
|
Copyright 2019-present Facebook Inc. All rights reserved.
|
|
This source code is licensed under the Apache 2.0 license found
|
|
in the LICENSE file in the root directory of this source tree.
|
|
*/}}
|
|
|
|
{{ define "dialect/sql/decode/one" }}
|
|
{{ $receiver := $.Receiver }}
|
|
|
|
// FromRows scans the sql response data into {{ $.Name }}.
|
|
func ({{ $receiver }} *{{ $.Name }}) FromRows(rows *sql.Rows) error {
|
|
{{- $scan := print "scan" $receiver }}
|
|
var {{ $scan }} struct {
|
|
ID {{ if $.ID.IsString }}int{{ else }}{{ $.ID.Type }}{{ end }}
|
|
{{ range $_, $f := $.Fields }}
|
|
{{- $f.StructField }} {{ $f.NullType }}
|
|
{{ end }}
|
|
}
|
|
// the order here should be the same as in the `{{ $.Package }}.Columns`.
|
|
if err := rows.Scan(
|
|
&{{ $scan }}.ID,
|
|
{{- range $_, $f := $.Fields }}
|
|
&{{ $scan }}.{{ $f.StructField }},
|
|
{{- end }}
|
|
); err != nil {
|
|
return err
|
|
}
|
|
{{ $receiver }}.ID = {{ if $.ID.IsString }}strconv.Itoa({{ $scan }}.ID){{ else }}{{ $scan }}.ID{{ end }}
|
|
{{- range $_, $f := $.Fields }}
|
|
{{- if $f.IsJSON }}
|
|
if value := {{ $scan }}.{{ $f.StructField }}; len(value) > 0 {
|
|
if err := json.Unmarshal(value, &{{ $receiver }}.{{ $f.StructField }}); err != nil {
|
|
return fmt.Errorf("unmarshal field {{ $f.Name }}: %v", err)
|
|
}
|
|
}
|
|
{{- else if $f.Nillable }}
|
|
if {{ $scan }}.{{ $f.StructField }}.Valid {
|
|
{{ $receiver }}.{{ $f.StructField }} = new({{ $f.Type }})
|
|
*{{ $receiver }}.{{ $f.StructField }} = {{ printf "%s.%s" $scan $f.StructField | $f.NullTypeField }}
|
|
}
|
|
{{- else }}
|
|
{{ $receiver }}.{{ $f.StructField }} = {{ printf "%s.%s" $scan $f.StructField | $f.NullTypeField }}
|
|
{{- end }}
|
|
{{- end }}
|
|
return nil
|
|
}
|
|
|
|
// scanValues returns the types for scanning values from sql.Rows.
|
|
func (*{{ $.Name }}) scanValues() []interface{} {
|
|
return []interface{} {
|
|
&{{ if not $.ID.UserDefined }}sql.NullInt64{{ else }}{{ $.ID.NullType }}{{ end }}{},
|
|
{{- range $_, $f := $.Fields }}
|
|
&{{ $f.NullType }}{},
|
|
{{- end }}
|
|
}
|
|
}
|
|
|
|
// assignValues assigns the values that were returned from sql.Rows (after scanning)
|
|
// to the {{ $.Name }} fields.
|
|
func ({{ $receiver }} *{{ $.Name }}) assignValues(values ...interface{}) error {
|
|
if m, n := len(values), len({{ $.Package }}.Columns); m != n {
|
|
return fmt.Errorf("mismatch number of scan values: %d != %d", m, n)
|
|
}
|
|
{{- if and $.ID.UserDefined (or $.ID.IsString $.ID.IsUUID) }}
|
|
{{- with extend $ "Idx" 0 "Field" $.ID "Rec" $receiver }}
|
|
{{ template "dialect/sql/decode/field" . }}
|
|
{{- end }}
|
|
{{- else }}
|
|
value, ok := values[0].(*sql.NullInt64)
|
|
if !ok {
|
|
return fmt.Errorf("unexpected type %T for field id", value)
|
|
}
|
|
{{ $receiver }}.ID = {{ if $.ID.IsString }}strconv.FormatInt(value.Int64, 10){{ else }}{{ $.ID.Type }}(value.Int64){{ end }}
|
|
{{- end }}
|
|
values = values[1:]
|
|
{{- range $i, $f := $.Fields }}
|
|
{{- with extend $ "Idx" $i "Field" $f "Rec" $receiver }}
|
|
{{ template "dialect/sql/decode/field" . }}
|
|
{{- end }}
|
|
{{- end }}
|
|
return nil
|
|
}
|
|
{{ end }}
|
|
|
|
{{ define "dialect/sql/decode/field" }}
|
|
{{- $i := $.Scope.Idx -}}
|
|
{{- $f := $.Scope.Field -}}
|
|
{{- $ret := $.Scope.Rec -}}
|
|
{{- if $f.IsJSON }}
|
|
if value, ok := values[{{ $i }}].(*{{ $f.NullType }}); !ok {
|
|
return fmt.Errorf("unexpected type %T for field {{ $f.Name }}", values[{{ $i }}])
|
|
} else if value != nil && len(*value) > 0 {
|
|
if err := json.Unmarshal(*value, &{{ $ret }}.{{ $f.StructField }}); err != nil {
|
|
return fmt.Errorf("unmarshal field {{ $f.Name }}: %v", err)
|
|
}
|
|
}
|
|
{{- else }}
|
|
{{- $nulltype := $f.NullType -}}
|
|
if value, ok := values[{{ $i }}].(*{{ $nulltype }}); !ok {
|
|
return fmt.Errorf("unexpected type %T for field {{ $f.Name }}", values[{{ $i }}])
|
|
{{- if hasPrefix $nulltype "sql" }}
|
|
} else if value.Valid {
|
|
{{- if $f.Nillable }}
|
|
{{ $ret }}.{{ $f.StructField }} = new({{ $f.Type }})
|
|
*{{ $ret }}.{{ $f.StructField }} = {{ $f.NullTypeField "value" }}
|
|
{{- else }}
|
|
{{ $ret }}.{{ $f.StructField }} = {{ $f.NullTypeField "value" }}
|
|
{{- end }}
|
|
{{- else }}
|
|
} else if value != nil {
|
|
{{ $ret }}.{{ $f.StructField }} = *value
|
|
{{- end }}
|
|
}
|
|
{{- end }}
|
|
{{- end }}
|
|
|
|
{{ define "dialect/sql/decode/many" }}
|
|
{{ $receiver := $.Receiver }}
|
|
{{ $slice := $.Scope.Slice }}
|
|
|
|
// FromRows scans the sql response data into {{ $slice }}.
|
|
func ({{ $receiver }} *{{ $slice }}) FromRows(rows *sql.Rows) error {
|
|
for rows.Next() {
|
|
{{- $scan := print "scan" $receiver }}
|
|
{{ $scan }} := &{{ $.Name }}{}
|
|
if err := {{ $scan }}.FromRows(rows); err != nil {
|
|
return err
|
|
}
|
|
*{{ $receiver }} = append(*{{ $receiver }}, {{ $scan }})
|
|
}
|
|
return nil
|
|
}
|
|
{{ end }}
|