go-zero/tools/goctl/model/sql/gen/insert.go

38 lines
1.0 KiB
Go
Raw Normal View History

2020-07-29 17:11:41 +08:00
package gen
import (
"bytes"
"strings"
"text/template"
2020-08-08 16:40:10 +08:00
sqltemplate "github.com/tal-tech/go-zero/tools/goctl/model/sql/template"
2020-07-29 17:11:41 +08:00
)
func genInsert(table *InnerTable) (string, error) {
t, err := template.New("insert").Parse(sqltemplate.Insert)
if err != nil {
return "", nil
}
insertBuffer := new(bytes.Buffer)
expressions := make([]string, 0)
expressionValues := make([]string, 0)
for _, filed := range table.Fields {
if filed.SnakeCase == "create_time" || filed.SnakeCase == "update_time" || filed.IsPrimaryKey {
continue
}
expressions = append(expressions, "?")
expressionValues = append(expressionValues, "data."+filed.UpperCamelCase)
}
err = t.Execute(insertBuffer, map[string]interface{}{
"upperObject": table.UpperCamelCase,
"lowerObject": table.LowerCamelCase,
"expression": strings.Join(expressions, ", "),
"expressionValues": strings.Join(expressionValues, ", "),
"containsCache": table.ContainsCache,
})
if err != nil {
return "", err
}
return insertBuffer.String(), nil
}