登录
首页 >  Golang >  Go问答

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

来源:stackoverflow

时间:2024-03-12 15:54:27 357浏览 收藏

你在学习Golang相关的知识吗?本文《SQL 变量在 Go 客户端的选择查询中未被更新》,主要介绍的内容就涉及到,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!

问题内容

我正在 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相同。它似乎没有动态更新。


解决方案


go 使用连接池,这意味着每个查询可能发生在不同的连接上。此类变量的范围仅限于连接。如果您需要它们在查询之间持续,则需要使用事务来确保保持在同一连接内。

您的查询确实是任意的。 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;

本篇关于《SQL 变量在 Go 客户端的选择查询中未被更新》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>