beego——原生SQL查询
使用Raw SQL查询,无需使用ORM表定义。
多数据库,都可直接使用占位符号?,自动转换。
查询时的参数,支持使用Model Struct和Slice,Array
1 2 | ids := []int{1, 2, 3} p.Raw( "SELECT name FROM user WHERE id IN (?, ?, ?)" , ids) |
创建一个RawSeter
1 2 3 | o := orm.NewOrm() var r RawSeter r = o.Raw( "UPDATE user SET name = ? WHERE name = ?" , "testing" , "slene" ) |
RawSeter接口中所包含的方法:
type RawSeter interface {
- Exec() (sql.Result, error)
- QueryRow(…interface{}) error
- QueryRows(…interface{}) (int64, error)
- SetArgs(…interface{}) RawSeter
- Values(*[]Params, …string) (int64, error)
- ValuesList(*[]ParamsList, …string) (int64, error)
- ValuesFlat(*ParamsList, string) (int64, error)
- RowsToMap(*Params, string, string) (int64, error)
- RowsToStruct(interface{}, string, string) (int64, error)
- Prepare() (RawPreparer, error)
}
Exec
执行sql语句,返回sql.Result对象
1 2 3 4 5 | res, err := o.Raw( "UPDATE user SET name = ?" , "your" ).Exec() if err == nil { num, _ := res.RowsAffected() fmt.Println( "mysql row affected nums: " , num) } |
QueryRow
QueryRow和QueryRows提供高级sql mapper功能。
支持struct
1 2 3 4 5 6 7 | type User struct { Id int UserName string } var user User err := o.Raw( "SELECT id, user_name FROM user WHERE id = ?" , 1).QueryRow(&user) |
QueryRows
QueryRows支持的对象还有map规则和QueryRow一样,但都是slice
1 2 3 4 5 6 7 8 9 10 | type User struct { Id int UserName string } var users []User num, err := o.Raw( "SELECT id, user_name FROM user WHERE id = ?" , 1).QueryRows(&users) if err == nil { fmt.Println( "user nums: " , num) } |
SetArgs
改变Raw(sql,args)中的args参数,返回一个新的RawSeter。
用于单条sql语句,重复利用,替换参数然后执行。
1 2 3 | res, err := r.SetArgs( "arg1" , "arg2" ).Exec() res, err := r.SetArgs( "arg1" , "arg2" ).Exec() ... |
Values / ValuesList / ValuesFlat
Raw SQL查询获得的结果集Value为string类型,NULL字段的值为空。
Values
以键值对的方式返回结果集
1 2 3 4 5 | var maps []orm.Params num, err := o.Raw( "SELECT user_name FROM user WHERE status = ?" , 1).Values(&maps) if err == nil && num > 0 { fmt.Println(maps[0][ "user_name" ]) // slene } |
valuesList
返回结果集slice
1 2 3 4 5 | var lists []orm.ParamsList num, err := o.Raw( "SELECT user_name FROM user WHERE status = ?" , 1).ValuesList(&lists) if err == nil && num > 0 { fmt.Println(lists[0][0]) // slene } |
ValuesFlat
返回单一字段的平铺slice数据。
1 2 3 4 5 | var list orm.ParamsList num, err := o.Raw( "SELECT id FROM user WHERE id < ?" , 10).ValuesFlat(&list) if err == nil && num > 0 { fmt.Println(list) // []{"1","2","3",...} } |
RowsToMap
查询结果匹配到map里
1 2 3 4 5 6 | res := make(orm.Params) nums, err := o.Raw( "SELECT name, value FROM options_table" ).RowsToMap(&res, "name" , "value" ) // res is a map[string]interface{}{ // "total": 100, // "found": 200, // } |
RowsToStruct
1 2 3 4 5 6 7 8 9 | type Options struct { Total int Found int } res := new(Options) nums, err := o.Raw( "SELECT name, value FROM options_table" ).RowsToStruct(res, "name" , "value" ) fmt.Println(res.Total) // 100 fmt.Println(res.Found) // 200 |
Prepare
用于一次prepare多次exec,以提高批量执行的速度。
1 2 3 4 5 6 | p, err := o.Raw( "UPDATE user SET name = ? WHERE name = ?" ).Prepare() res, err := p.Exec( "testing" , "slene" ) res, err = p.Exec( "testing" , "astaxie" ) ... ... p.Close() // 别忘记关闭 statement |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
2017-12-16 API的理解和使用——哈希类型的命令
2017-12-16 API的理解和使用——字符串的命令
2017-12-16 API的理解和使用——全局命令