[Beego模型] 四、使用SQL语句进行查询
2017-08-17 10:32
645 查看
[Beego模型] 一、ORM 使用方法
[Beego模型] 二、CRUD 操作
[Beego模型] 三、高级查询
[Beego模型] 四、使用SQL语句进行查询
[Beego模型] 五、构造查询
[Beego模型] 六、事务处理
使用 Raw SQL 查询,无需使用 ORM 表定义
多数据库,都可直接使用占位符号
查询时的参数,支持使用 Model Struct 和 Slice, Array
创建一个 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)
}
支持 struct
用于单条 sql 语句,重复利用,替换参数然后执行。
from beego 1.1.0
Values, ValuesList, ValuesFlat 的参数,可以指定返回哪些 Columns 的数据
通常情况下,是无需指定的,因为 sql 语句中你可以自行设置 SELECT 的字段
查询结果匹配到 map 里
查询结果匹配到 struct 里
匹配支持的名称转换为 snake -> camel, eg: SELECT user_name … 需要你的 struct 中定义有 UserName
摘自:https://beego.me/docs/mvc/model/rawsql.md
[Beego模型] 二、CRUD 操作
[Beego模型] 三、高级查询
[Beego模型] 四、使用SQL语句进行查询
[Beego模型] 五、构造查询
[Beego模型] 六、事务处理
使用 Raw SQL 查询,无需使用 ORM 表定义
多数据库,都可直接使用占位符号
?,自动转换
查询时的参数,支持使用 Model Struct 和 Slice, Array
ids := []int{1, 2, 3} p.Raw("SELECT name FROM user WHERE id IN (?, ?, ?)", ids)
创建一个 RawSeter
o := orm.NewOrm() var r RawSeter r = o.Raw("UPDATE user SET name = ? WHERE name = ?", "testing", "slene")
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 对象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
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 一样的,但都是 slicetype 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 语句,重复利用,替换参数然后执行。
res, err := r.SetArgs("arg1", "arg2").Exec() res, err := r.SetArgs("arg1", "arg2").Exec() ...
Values / ValuesList / ValuesFlat
Raw SQL 查询获得的结果集 Value 为string类型,NULL 字段的值为空 ``
from beego 1.1.0
Values, ValuesList, ValuesFlat 的参数,可以指定返回哪些 Columns 的数据
通常情况下,是无需指定的,因为 sql 语句中你可以自行设置 SELECT 的字段
Values
返回结果集的 key => value 值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
返回结果集 slicevar 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 数据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
SQL 查询结果是这样name | value |
total | 100 |
found | 200 |
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
SQL 查询结果是这样name | value |
total | 100 |
found | 200 |
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
匹配支持的名称转换为 snake -> camel, eg: SELECT user_name … 需要你的 struct 中定义有 UserName
Prepare
用于一次 prepare 多次 exec,以提高批量执行的速度。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
摘自:https://beego.me/docs/mvc/model/rawsql.md
相关文章推荐
- excel内一键进行sql查询(使用方法 1.选择’需要进行sql查询区域 包括字段名 2 输入sql语句 3.选择输出数据的单元格)
- 在Hibernate中使用HibernateTemplate来进行包含sql语句的查询
- Oracle使用SQL语句进行递归查询
- hibernate中使用sql语句进行表链接查询,对结果集的遍历方法
- 两种使用nuzt接收动态参数编写SQL语句进行分页查询
- 在Excel中使用SQL语句对多个数据表进行精确筛选 (查询)
- 在Hibernate中使用HibernateTemplate来进行包含sql语句的查询
- Python与开源GIS:在OGR中使用SQL语句进行查询
- 在ORM框架中使用原生sql语句进行聚合查询遇到的问题
- 使用SQL语句对表进行分页查询
- Excel 中使用SQL 语句查询数据(七)-----用LIKE 运算符进行模糊匹配查询
- Hibernate中使用原生的sql语句进行查询操作
- Hibernate基础-使用标准SQL语句进行查询
- Excel 中使用SQL 语句查询数据(八)-----用Group by 进行分组统计
- 使用Query进行HQL语句查询和SQL语句查询
- 一个表里有多个字段需要同时使用字典表进行关联显示,如何写sql查询语句
- hinernate--推荐使用原生SQL语句进行查询(效率高)
- 在SQL中使用convert函数进行日期的查询
- SQL查询语句使用
- 数据库知识-SQL查询语句精华使用简要