0
UPDATE `play`
SET `counter1` = `counter1` + LEAST(`maxchange`, FLOOR(`x`/`y`)),
`counter2` = `counter2` - LEAST(`maxchange`, FLOOR(`x`/`y`)),
`x` = MOD(`x`, `y`)
WHERE `x` > `y`
AND `maxchange` > 0
正如你所看到的,LEAST(maxchange, FLOOR(x/y))
被多次使用,但它應該始終具有相同的值。有沒有一種方法來優化這個,只計算一次?
我在PHP中編寫了這個代碼,用於記錄。