MySQL字符串進行加減乘除的運算


 原文鏈接:https://www.jianshu.com/p/2ab2c0dc3cb5

在mysql當中,字符串類型間進行加減乘除運算的時候,會截取字符串以數字開頭的那一部分數字進行運算,如果字符串前面沒有數字,那么就只能截取的數值為0,那么進行加減的時候結果都是0,進行乘除的時候結果都是NULL,如下幾個結果說明問題:

mysql> select '1a'+'1b'; +-----------+ | '1a'+'1b' | +-----------+ | 2 | +-----------+ 1 row in set, 2 warnings (0.00 sec)
mysql> select '2a'-'1b'; +-----------+ | '2a'-'1b' | +-----------+ | 1 | +-----------+ 1 row in set, 2 warnings (0.00 sec) 
mysql> select '1a'/'2b'; +-----------+ | '1a'/'2b' | +-----------+ | 0.5 | +-----------+ 1 row in set, 2 warnings (0.00 sec) 
mysql> select 'a'/'b'; +---------+ | 'a'/'b' | +---------+ | NULL | +---------+ 1 row in set, 3 warnings (0.00 sec) 
mysql> select 'a' - 'b'; +-----------+ | 'a' - 'b' | +-----------+ | 0 | +-----------+ 1 row in set, 2 warnings (0.00 sec) 
mysql> select 'a' + 'b'; +-----------+ | 'a' + 'b' | +-----------+ | 0 | +-----------+ 1 row in set, 2 warnings (0.00 sec) 

如果一個字符串以數字開頭,后面有非數字和數字組合的話,在進行運算的時候,會省略掉非數字和數字組合那一段,也就是只會截取開頭的數字

mysql> select '2015-2-1' - '2015-1-1'; +-------------------------+ | '2015-2-1' - '2015-1-1' | +-------------------------+ | 0 | +-------------------------+ 1 row in set, 2 warnings (0.00 sec) 

以上相當於2015-2015=0

mysql當字符串進行大小比較的時候

mysql> select '2015-2-1' > '2015-1-1'; +-------------------------+ | '2015-2-1' > '2015-1-1' | +-------------------------+ | 1 | +-------------------------+ 1 row in set (0.00 sec) 
mysql> select '2015-2-1' < '2015-1-1'; +-------------------------+ | '2015-2-1' < '2015-1-1' | +-------------------------+ | 0 | +-------------------------+ 1 row in set (0.00 sec) 

在這里非常奇怪,'2015-2-1' - '2015-1-1' = 0,為什么大小比較的時候會有大小之分呢?

原來對於數字與非數字混合的字符串,在進行大小比較的時候,如果兩字符串長度相等,那么兩字符串就會比較相同位置的字符,比較時若字符是數字,則直接比較,若字符是非數字那么會轉換為ascii碼進行比較,若在某位置上已經有大小之分,那么就不會再進行比較。

mysql> select '2017-03-20 15:27:49' > '2017-03-20 15:27:48'; +-----------------------------------------------+ | '2017-03-20 15:27:49' > '2017-03-20 15:27:48' | +-----------------------------------------------+ | 1 | +-----------------------------------------------+ 1 row in set (0.00 sec) 

看起來像日期的字符串可以用date_format函數提取當中的年月日,看如下:

mysql> select date_format('2017/03/20 15:27:49','%Y') 年,date_format('2017/03/20 15:27:49','%c') 月,date_format('2017/03/20 15:27:49','%d') 日; +------+------+------+ | 年 | 月 | 日 | +------+------+------+ | 2017 | 3 | 20 | +------+------+------+ 1 row in set (0.00 sec) 

非數字字符在比較大小的時候,就例如:

mysql> select 'a' < 'b'; +-----------+ | 'a' < 'b' | +-----------+ | 1 | +-----------+ 1 row in set (0.00 sec) 

當中的字母會轉成ascii碼,再進行比較,以上是單字母字符串比較,如果是多字母數字混合字符串比較呢?

mysql> select '1c' > 'bc'; +-------------+ | '1c' > 'bc' | +-------------+ | 0 | +-------------+ 1 row in set (0.00 sec) 
mysql> select '1yz' > 'abc999'; +------------------+ | '1yz' > 'abc999' | +------------------+ | 0 | +------------------+ 1 row in set (0.00 sec) 

其實從上面的結果大概可以猜測得到,為讓解釋更清晰更有說服力,再看下圖:

mysql> select ascii('1c'),ascii('bc'); +-------------+-------------+ | ascii('1c') | ascii('bc') | +-------------+-------------+ | 49 | 98 | +-------------+-------------+ 1 row in set (0.00 sec) 
mysql> select ascii('1yz'),ascii('abc999'); +--------------+-----------------+ | ascii('1yz') | ascii('abc999') | +--------------+-----------------+ | 49 | 97 | +--------------+-----------------+ 1 row in set (0.00 sec) 

字符串大小比較的時候,會從左向右將兩個字符串第一個不相等的兩個字符的ascii碼的比較結果作為最終結果




免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM