簡體   English   中英

@variable:= variable2在MySQL查詢中是什么意思?

[英]What does @variable := variable2 mean in a MySQL query?

我的代碼中select ifselect if內包含以下查詢,並且我不記得包含@lastComment := time實際上是什么?

SELECT 
    IF(
        (SELECT @lastComment := `time` 
         FROM usermessages 
         WHERE userId = $userId 
         ORDER BY id DESC 
         LIMIT 1)
    IS NOT NULL,
    DATE_SUB(NOW(), INTERVAL 30 SECOND) >= @lastComment, 1
    )

看起來@lastComment只是保留時間的臨時變量,但我不明白為什么需要它,僅僅是將其傳遞給其他查詢嗎?

顯然,您不想執行兩次查詢,這是正確的,但是您可以輕松省略用戶定義的變量,從而使其更清晰:

SELECT 
  IFNULL(
     (
       SELECT DATE_SUB(NOW(), INTERVAL 30 SECOND) >= `time` 
       FROM usermessages 
       WHERE userId = $userId 
       ORDER BY id DESC 
       LIMIT 1
     )
     , 1
)

轉換為:

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM