天天看點

mysql内進行加減乘除_MySQL字元串進行加減乘除的運算

在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碼的比較結果作為最終結果