1 Star 1 Fork 0

1701/gpa

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
delete-by.go 4.40 KB
一键复制 编辑 原始数据 按行查看 历史
1701 提交于 2021-09-04 16:34 . 更新
package method
import (
"strings"
"gitee.com/knowgo/gpa/engine/generator/defines"
rdesc "gitee.com/knowgo/gpa/engine/generator/repo-desc"
"gitee.com/knowgo/gpa/engine/generator/sqlgenerator"
)
type deleteby struct {
BaseMethod
}
func (g *deleteby) Test(fn *defines.Func) bool {
if strings.Index(fn.Name, "Delete") == 0 {
if strings.Index(fn.Name, "By") > 0 {
g.BaseMethod.Test(fn)
fn.Template = defines.DELETE
return true
}
}
return false
}
// func (g *deleteby) where(fd *rdesc.FuncDesc, whereParams []*intf.SQLParam) error {
// // var params []*desc.SQLParam
// // var fieldMap = map[string]bool{}
// // 组织 where 参数
// for _, p := range whereParams {
// // name = utils.LowerFirstChar(name)
// // fieldMap[p.SQLParamFieldName] = true
// if p.IsInOperator {
// fd.DBUtilPackage = g.fn.AddDBUtilPackage()
// }
// found := false
// for _, arg := range g.fn.Params {
// if arg.Type.IsContext() || arg.Type.IsStruct() || arg.IsFunc() {
// // 以上三种类型不能作为 where 参数
// continue
// }
// if arg.Name == utils.LowerFirstChar(p.SQLParamName) {
// // 找到输入参数
// p.VarName = arg.Name
// if p.IsInOperator {
// // arg.IsSlice
// if !arg.Slice {
// return fmt.Errorf("arg [%s] shuld be array", p.VarName)
// }
// }
// // params = append(params, &desc.SQLParam{
// // VarName: arg.Name,
// // })
// found = true
// }
// }
// if !found {
// if fd.Input.Bean != nil {
// for _, f := range fd.Input.Bean.Type.Bean.Fields {
// if f.GoVarName == p.SQLParamName && !f.Type.IsJson() {
// // 找到输入参数
// p.VarName = fd.Input.Bean.Name + "." + f.GoVarName
// if p.IsInOperator {
// // 判断是否是数组类型,如果不是数组则报出类型错误
// if !f.Type.IsSlice {
// return fmt.Errorf("arg [%s] shuld be array", p.VarName)
// }
// // if !f.Type {
// // return fmt.Errorf("arg [%s] shuld be array", p.VarName)
// // }
// }
// if f.SQLType.IsTime() {
// fd.DBUtilPackage = g.fn.AddDBUtilPackage()
// var timeProp = &dbutil.TimePropDesc{
// TypeName: f.SQLType.Name,
// Nullable: f.Nullable,
// }
// if f.TimeZone != nil {
// timeProp.TimeZone = f.TimeZone.String()
// }
// p.VarAlias = fd.NextVarName()
// p.Time = true
// p.TimeProp = timeProp
// // params = append(params, &desc.SQLParam{
// // VarName: fd.Input.Bean.Name + "." + f.GoVarName,
// // VarAlias: fd.NextVarName(),
// // Time: true,
// // TimeProp: timeProp,
// // })
// }
// // else {
// // params = append(params, &desc.SQLParam{
// // VarName: fd.Input.Bean.Name + "." + f.GoVarName,
// // })
// // }
// found = true
// }
// }
// }
// }
// if !found {
// return fmt.Errorf("no where param [%s] found in func args", p.VarName)
// // return
// }
// }
// return nil
// }
func (g *deleteby) Parse() (*rdesc.FuncDesc, error) {
byIdx := strings.Index(g.fn.Name, "By")
if byIdx < 6 {
return nil, g.fn.CreateError("invalid name of DeleteXXXBy func")
}
fd := rdesc.NewFuncDesc(g.fn, 3, g.sqlg, g.logger)
if err := fd.Explain(); err != nil {
return nil, g.fn.CreateError(err.Error())
}
// fd, err := desc.Explain(g.fn, 3, false, nil)
// // rst, err := desc.ParseResult(g.fn, 2)
// if err != nil {
// return nil, g.fn.CreateError(err.Error())
// }
if fd.BeanObj == nil {
return nil, g.fn.CreateError("no struct bean found in funcion")
}
if err := g.CheckDeleteReturns(fd); err != nil {
return nil, g.fn.CreateError(err.Error())
}
whereInName := g.fn.Name[byIdx+2:]
sqlWhere, whereParams, err := parseWhereFromFuncName(whereInName, g.sqlg)
if err != nil {
return nil, g.fn.CreateError(err.Error())
}
if _, err = g.prepareParams(fd, whereParams, false); err != nil {
return nil, g.fn.CreateError(err.Error())
}
// sql := strings.Builder{}
// sqlParams := []*desc.SQLParam{}
// columns := []string{}
bean, err := fd.BeanObj.GetBeanType()
if err != nil {
return nil, g.fn.CreateError(err.Error())
}
var sql = sqlgenerator.SQL{
TableName: bean.TableName,
Where: sqlWhere,
WhereParams: whereParams,
}
fd.SQL, fd.SQLWhereParams = g.sqlg.Delete(&sql) // sql.CreateDelete() // append(sqlParams, whereParams...)
return fd, nil
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/knowgo/gpa.git
git@gitee.com:knowgo/gpa.git
knowgo
gpa
gpa
v0.2.0

搜索帮助