本文介紹了MySQL 查詢 - 比較版本號的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧!
問題描述
限時送ChatGPT賬號..
我的其中一個 SQL 表中有一個字段用于存儲版本號,例如 '3.4.23'
或 '1.224.43'
.
I have a field in one of my SQL tables which stores a version number, like '3.4.23'
or '1.224.43'
.
有沒有辦法為這個字段使用大于條件?
Is there a way to use a greater than condition for this field?
SELECT * FROM versions WHERE version_number >'2.1.27'
推薦答案
感謝@symcbean 和@gordon-linoff 的提示,我的最終查詢?nèi)缦滤?
Thanks for the tips @symcbean and @gordon-linoff, my final query looks like this:
SELECT *
FROM versions WHERE CONCAT(
LPAD(SUBSTRING_INDEX(SUBSTRING_INDEX(version_number, '.', 1), '.', -1), 10, '0'),
LPAD(SUBSTRING_INDEX(SUBSTRING_INDEX(version_number, '.', 2), '.', -1), 10, '0'),
LPAD(SUBSTRING_INDEX(SUBSTRING_INDEX(version_number, '.', 3), '.', -1), 10, '0')
) > CONCAT(LPAD(2,10,'0'), LPAD(1,10,'0'), LPAD(27,10,'0'));
這允許每個組件的長度最多為 10 位.
This allows each component to be up to 10 digits long.
它改變了這個:
X.XX.XXX > 2.1.27
為此:
'000000000X00000000XX0000000XXX' > '000000000200000000010000000027'
這篇關(guān)于MySQL 查詢 - 比較版本號的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網(wǎng)!
【網(wǎng)站聲明】本站部分內(nèi)容來源于互聯(lián)網(wǎng),旨在幫助大家更快的解決問題,如果有圖片或者內(nèi)容侵犯了您的權(quán)益,請聯(lián)系我們刪除處理,感謝您的支持!