簡體   English   中英

MySQL MAX()函數用於比較更新中的數值?

[英]MySQL MAX() function to compare numeric values in an update?

更新行時,我希望有一個內置的檢查來進行一些邊界檢查。 大多數語言都有一個MAX()函數來返回傳遞的參數的最大值,但MySQL似乎使用MAX()來做其他事情。 例如:

UPDATE person SET dollars = MAX(0, dollars-20) WHERE id=1

我想從人id 1減去20美元,但我不希望美元永遠用負值表示,所以我希望與0進行內置比較。這有用嗎? 或者還有另一種方式嗎? 謝謝!

MySQL支持一個名為GREATEST()的函數。 它返回其參數列表中的最大值。

UPDATE person SET dollars = GREATEST(0, dollars-20) WHERE id=1

這不是ANSI SQL中的標准函數,因此不要指望它在其他品牌的SQL數據庫中可用。 如果您需要獨立於供應商的解決方案,請使用其他人建議的CASE語法。 但如果你需要使用的只是MySQL,這個功能更簡潔。

暫無
暫無

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

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