我正在 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 使用連接池,這意味著每個查詢可能發生在不同的連接上。類似的變量的作用域是連接。如果您需要它們在查詢之間持續存在,則需要使用事務來確保保持在同一連接內。

慕慕森
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;
- 2 回答
- 0 關注
- 179 瀏覽
添加回答
舉報
0/150
提交
取消