MySQL中字符串比較大小詳解(日期字符串比較問題)
前言
數(shù)據(jù)庫中在對(duì)于數(shù)字與非數(shù)字混合的字符串,在進(jìn)行大小比較的時(shí)候,如果兩字符串長度相等,那么兩字符串就會(huì)比較相同位置的字符,比較時(shí)若字符是數(shù)字,則直接比較,若字符是非數(shù)字那么會(huì)轉(zhuǎn)換為ascii碼進(jìn)行比較,若在某位置上已經(jīng)有大小之分,那么就不會(huì)再進(jìn)行比較。
如上所述,當(dāng)字符串用于比較時(shí)間格式數(shù)據(jù)進(jìn)行時(shí)間維度的比較時(shí)會(huì)出現(xiàn)問題。如以下sql進(jìn)行查詢時(shí)
select * FROM work_day_content as wdc WHERE wdc.work_day >= '2019-09-30 00:00:00' AND wdc.work_day<= '2019-10-06 00:00:00'
? 圖1-1
如圖1-1所示,沒有查詢出任何條件
當(dāng)使用日期函數(shù)把字符串轉(zhuǎn)化為日期時(shí)
select * FROM work_day_content as wdc where date(wdc.work_day) >= date('2019-09-30 00:00:00' ) AND date(wdc.work_day)<= date('2019-09-30 00:00:00' )
? 圖1-2
如圖1-2所示,查出了符合條件的數(shù)據(jù)
分析為何第一個(gè)sql語句沒有查詢出內(nèi)容。由于該字段使用的是字符串形式存儲(chǔ),因此此時(shí)比較大小采用的是字符串方式比較大小。
字符串方式比較大小是從左往右進(jìn)行匹配。對(duì)于長度不同的字符串進(jìn)行匹配時(shí)。較短字符串比較完后還沒有大小之分。則較長的字符串較大。如下面sql所示
select '2019-09-30 ' < '2019-09-30 00:00:00'
發(fā)現(xiàn)此時(shí)**字符串’2019-09-30 00:00:00’**較大。因此之前的sql沒有查出日期為2019-09-30的數(shù)據(jù)
因此。在使用字符串表示時(shí)間時(shí),需要使用時(shí)間函數(shù)進(jìn)行比較。
sql提供的時(shí)間函數(shù)有:date(), str_to_date()
另外,在mysql當(dāng)中,字符串類型間進(jìn)行加減乘除運(yùn)算的時(shí)候,會(huì)截取字符串以數(shù)字開頭的那一部分?jǐn)?shù)字進(jìn)行運(yùn)算,如果字符串前面沒有數(shù)字,那么就只能截取的數(shù)值為0,那么進(jìn)行加減的時(shí)候結(jié)果都是0,進(jìn)行乘除的時(shí)候結(jié)果都是NULL。
總結(jié)
到此這篇關(guān)于MySQL中字符串比較大小的文章就介紹到這了,更多相關(guān)MySQL字符串比較大小內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
簡單了解MySQL數(shù)據(jù)庫優(yōu)化技巧
這篇文章主要介紹了簡單了解MySQL數(shù)據(jù)庫優(yōu)化技巧,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07mysql如何創(chuàng)建數(shù)據(jù)庫并指定字符集
這篇文章主要介紹了mysql如何創(chuàng)建數(shù)據(jù)庫并指定字符集問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12