sqlboiler/cmds/templates/insert.tpl

48 lines
1.5 KiB
Smarty
Raw Normal View History

2016-03-23 07:18:41 +01:00
{{- $tableNameSingular := titleCaseSingular .Table.Name -}}
// {{$tableNameSingular}}Insert inserts a single record.
func (o *{{$tableNameSingular}}) Insert(whitelist ... string) error {
if o == nil {
return 0, errors.New("{{.PkgName}}: no {{.Table.Name}} provided for insertion")
}
if err := o.doBeforeCreateHooks(); err != nil {
return 0, err
}
var rowID int
err := boil.GetDB().QueryRow(`INSERT INTO {{.Table.Name}} ({{insertParamNames .Table.Columns}}) VALUES({{insertParamFlags .Table.Columns}}) RETURNING id`, {{insertParamVariables "o." .Table.Columns}}).Scan(&rowID)
if err != nil {
return 0, fmt.Errorf("{{.PkgName}}: unable to insert {{.Table.Name}}: %s", err)
}
if err := o.doAfterCreateHooks(); err != nil {
return 0, err
}
return rowID, nil
}
func (o *{{$tableNameSingular}}) InsertX(exec boil.Executor, whitelist ... string) error {
2016-02-23 13:38:24 +01:00
if o == nil {
2016-03-23 07:18:41 +01:00
return 0, errors.New("{{.PkgName}}: no {{.Table.Name}} provided for insertion")
2016-02-23 13:38:24 +01:00
}
if err := o.doBeforeCreateHooks(); err != nil {
return 0, err
}
2016-02-23 13:38:24 +01:00
var rowID int
err := boil.GetDB().QueryRow(`INSERT INTO {{.Table.Name}} ({{insertParamNames .Table.Columns}}) VALUES({{insertParamFlags .Table.Columns}}) RETURNING id`, {{insertParamVariables "o." .Table.Columns}}).Scan(&rowID)
2016-02-23 13:38:24 +01:00
if err != nil {
2016-03-23 07:18:41 +01:00
return 0, fmt.Errorf("{{.PkgName}}: unable to insert {{.Table.Name}}: %s", err)
2016-02-23 13:38:24 +01:00
}
if err := o.doAfterCreateHooks(); err != nil {
return 0, err
}
2016-02-23 13:38:24 +01:00
return rowID, nil
}