在mysql当中,字符串类型间进行加减乘除运算的时候,会截取字符串以数字开头的那一部分数字进行运算,如果字符串前面没有数字,那么就只能截取的数值为0,那么进行加减的时候结果都是0。

一、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码的比较结果作为最终结果。
延伸阅读:
二、什么是数据库
数据库就是英文的“database”翻译来的,data + base,故名思义就是数据的根源,数据的基础。那么为什么要有数据库呢,数据库首先是个计算机软件,在所谓数据库诞生之前,常用方法可能是程序员自己写一个小程序来完成数据处理分析这样的工作。
伴随着计算机的普及,越来越多的场景开始使用计算机,产生了越来越多的数据,也催生了越来越多的数据分析需求。为了降低数据分析的门槛,让更多人能够更方便高效地管理分析数据,工程师们就打造了一种专门的软件来帮助人们对数据进行合理的存储以提高存取效率,提供易用的接口和丰富的分析算法以方便使用,集成有效的管理工具以提高数据安全性等等,这就是数据库,也被称为数据库管理系统(DBMS,Database management system)。
数据库是一整套数据管理体系,包括数据存储的模型、数据组织的架构、数据分析的算法、数据管理的工具以及数据访问的接口等等。
