为了账号安全,请及时绑定邮箱和手机立即绑定

Go 客户端的选择查询中的 SQL 变量未更新

Go 客户端的选择查询中的 SQL 变量未更新

Go
慕娘9325324 2023-06-26 17:38:11
我正在 SQL 中运行以下查询。SET @thisid=0;SET @serial=0;SELECT @serial := IF((@thisid != `places`.`id`), @serial + 1, @serial) as `serial`, @thisid := `places`.`id`, `places`.`id` FROM `places`;仅当新 id 与上一个 id 不同时,变量 @serial 基本上才会递增。在终端中运行这些查询并打印 @serial 和 @thisid 的值时,收到的值是 @thisid='id6' @serial=6。我在我的 go 代码中执行了这个查询:if _, err = repo.db.ExecContext(ctx, "SET @thisid=0;"); err != nil {    return}if _, err = repo.db.ExecContext(ctx, "SET @serial=0;"); err != nil {    return}rows, err = repo.db.QueryContext(ctx, fmt.Sprintf(    "SELECT @serial := IF((@thisid != `places`.`id`), @serial + 1, @serial) as `serial`, @thisid := `places`.`id`, `places`.`id` FROM `places`;",))if err != nil {    fmt.Println("error here")    return}if err = repo.db.QueryRow("SELECT @serial").Scan(&that); err != nil {    return}if err = repo.db.QueryRow("SELECT @thisid").Scan(&this); err != nil {    return}打印@thisid和@serial的值时,@thisid的值与@serial的值接收为0相同。它似乎没有动态更新。
查看完整描述

2 回答

?
www说

TA贡献1775条经验 获得超8个赞

Go 使用连接池,这意味着每个查询可能发生在不同的连接上。类似的变量的作用域是连接。如果您需要它们在查询之间持续存在,则需要使用事务来确保保持在同一连接内。



查看完整回答
反对 回复 2023-06-26
?
慕慕森

TA贡献1856条经验 获得超17个赞

你的查询真的很随意。MySQL 不保证select. 它也不保证结果集的顺序。


所以,我想你想要:


select p.*,

       (@rn := if(@id = id, @rn + 1,

                  if(@id := id, 1, 1)

                 )

       ) as serial

from (select p.*

      from places p

      order by p.id

     ) p cross join

     (select @id := 0, @rn := 0) params;


查看完整回答
反对 回复 2023-06-26
  • 2 回答
  • 0 关注
  • 129 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信