You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 11 Next »

Update更新方法

Update用于数据的更新,往往需要结合DataWhere方法共同使用。Data方法用于指定需要更新的数据,Where方法用于指定更新的条件范围。同时,Update方法也支持直接给定数据和条件参数。

使用示例:

// UPDATE `user` SET `name`='john guo' WHERE name='john'
r, err := db.Table("user").Data(g.Map{"name" : "john guo"}).Where("name", "john").Update()
r, err := db.Table("user").Data("name='john guo'").Where("name", "john").Update()
// UPDATE `user` SET `status`=1 ORDER BY `login_time` asc LIMIT 10
r, err := db.Table("user").Data("status", 1).Order("login_time asc").Limit(10).Update()

// UPDATE `user` SET `status`=1
r, err := db.Table("user").Data("status=1").Update()
r, err := db.Table("user").Data("status", 1).Update()
r, err := db.Table("user").Data(g.Map{"status" : 1}).Update()

也可以直接给Update方法传递datawhere参数:

// UPDATE `user` SET `name`='john guo' WHERE name='john'
r, err := db.Table("user").Update(g.Map{"name" : "john guo"}, "name", "john")
r, err := db.Table("user").Update("name='john guo'", "name", "john")

// UPDATE `user` SET `status`=1
r, err := db.Table("user").Update("status=1")
r, err := db.Table("user").Update(g.Map{"status" : 1})

Counter更新特性

可以使用Counter类型参数对特定的字段进行数值操作,例如:增加、减少操作。

Counter数据结构定义:

// Counter  is the type for update count.
type Counter struct {
	Field string
	Value float64
}

Counter使用示例

gdbCounter := &gdb.Counter{
	Field: "views",
	Value: 1,
}
updateData := g.Map{
	"views": gdbCounter,
}
// UPDATE `article` SET `views`=`views`+1 WHERE `id`=1
result, err := db.Update("article", updateData, "id", 1)

RawSQL语句嵌入

gdb.Raw是字符串类型,该类型的参数将会直接作为SQL片段嵌入到提交到底层的SQL语句中,不会被自动转换为字符串参数类型、也不会被当做预处理参数。例如:

// UPDATE `user` SET login_count='login_count+1',update_time='now()' WHERE id=1
db.Model("user").Data(g.Map{
    "login_count": "login_count+1",
    "update_time": "now()",
}).Where("id", 1).Update()
// 执行报错:Error Code: 1136. Column count doesn't match value count at row 1

使用gdb.Raw改造后:

// UPDATE `user` SET login_count=login_count+1,update_time=now() WHERE id=1
db.Model("user").Data(g.Map{
    "login_count": gdb.Raw("login_count+1"),
    "update_time": gdb.Raw("now()"),
}).Where("id", 1).Update()

Delete删除方法

Delete方法用于数据的删除。

使用示例

// DELETE FROM `user` WHERE uid=10
r, err := db.Table("user").Where("uid", 10).Delete()
// DELETE FROM `user` ORDER BY `login_time` asc LIMIT 10
r, err := db.Table("user").Order("login_time asc").Limit(10).Delete()

也可以直接给Delete方法传递where参数:

// DELETE FROM `user` WHERE `uid`=10
r, err := db.Table("user").Delete("uid", 10)
// DELETE FROM `user` WHERE `score`<60
r, err := db.Table("user").Delete("score < ", 60)
Content Menu

  • No labels