美文网首页Java\Android相关程序员服务器后端开发
mysql之字符串进行运算或大小比较

mysql之字符串进行运算或大小比较

作者: 不姓马的小马哥 | 来源:发表于2017-03-20 15:58 被阅读906次

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码的比较结果作为最终结果

相关文章

  • mysql之字符串进行运算或大小比较

    mysql字符串进行加减乘除的运算: 在mysql当中,字符串类型间进行加减乘除运算的时候,会截取字符串以数字开头...

  • js 运算时数据类型转化, == 和 ===

    只有加法运算会把运算子转换成字符串,其他运算都自动转化成数值大小比较时会先转化成数字类型再进行比较一元运算符也会把...

  • js 各种基础类型的转换(下)隐式转换

    前言 在进行比较运算,或者进行四则运算时,常常会触发JS中的隐式转换机制。 非字符串到字符串的类型转换 加号运算符...

  • SQL查漏补缺

    MySQL按照以下规则进行数值比较: 若函数中有一个或两个参数都是NULL,则比较运算的结果为NULL,除非是等号...

  • C语言比较字符串的几个函数

    strcmp() 对两个字符串进行大小写敏感的比较 strcmpi() 对两个字符串进行大小写不敏感的比较 ...

  • 4.2 比较运算符

    比较运算符的作用是通过对值进行比较,返回一个布尔型的结果(部分运算符除外)。如果比较一个数字和一个字符串(或包含数...

  • js 基础知识随笔

    js 比较运算, 如果字符串和数值比较会先将字符串转为数值再进行比较 如果是对象和字符串比较则会调用对象的valu...

  • 4、python的各种运算

    字符串的运算:加法,成员运算,比较运算,逻辑运算

  • PHP 比较运算符

    是针对数字的大小进行比较的运算。 如果不是数字,会自动转换为数字。 运算符包括:> >= <= == === !=...

  • 不同数据类型的隐形转换

    1数字和字符串、布尔类型、数组进行比较时,字符串(或布尔类型、或数组)先转换为数字(Number),再进行比较; ...

网友评论

  • ouhahaha:"原因非常明显了,字符串大小比较的时候,只会将第一个字符转换成ascii码进行比较."
    这句话有错误,应该是“字符串大小比较的时候,会从左向右将两个字符串第一个不相等的两个字符的ascii码的比较结果作为最终结果”。
    直接对两个字符串分别作ascii()操作,没有多大意义哈
    不姓马的小马哥:谢谢大佬,已改正

本文标题:mysql之字符串进行运算或大小比较

本文链接:https://www.haomeiwen.com/subject/mnqinttx.html