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

  1. mysql当中,字符串类型间进行加减乘除运算的时候,会截取字符串以数字开头的那一部分数字进行运算,如果字符串前面没有数字,那么就只能截取的数值为0,那么进行加减的时候结果都是0,进行乘除的时候结果都是NULL,如下几个结果说明问题:
  2. mysql> select '1a'+'1b';
  3. +-----------+
  4. | '1a'+'1b' |
  5. +-----------+
  6. | 2 |
  7. +-----------+
  8. 1 row in set, 2 warnings (0.00 sec)
  1. mysql> select '2a'-'1b';
  2. +-----------+
  3. | '2a'-'1b' |
  4. +-----------+
  5. | 1 |
  6. +-----------+
  7. 1 row in set, 2 warnings (0.00 sec)
  1. mysql> select '1a'/'2b';
  2. +-----------+
  3. | '1a'/'2b' |
  4. +-----------+
  5. | 0.5 |
  6. +-----------+
  7. 1 row in set, 2 warnings (0.00 sec)
  1. mysql> select 'a'/'b';
  2. +---------+
  3. | 'a'/'b' |
  4. +---------+
  5. | NULL |
  6. +---------+
  7. 1 row in set, 3 warnings (0.00 sec)
  1. mysql> select 'a' - 'b';
  2. +-----------+
  3. | 'a' - 'b' |
  4. +-----------+
  5. | 0 |
  6. +-----------+
  7. 1 row in set, 2 warnings (0.00 sec)
  1. mysql> select 'a' + 'b';
  2. +-----------+
  3. | 'a' + 'b' |
  4. +-----------+
  5. | 0 |
  6. +-----------+
  7. 1 row in set, 2 warnings (0.00 sec)

如果一个字符串以数字开头,后面有非数字和数字组合的话,在进行运算的时候,会省略掉非数字和数字组合那一段,也就是只会截取开头的数字

  1. mysql> select '2015-2-1' - '2015-1-1';
  2. +-------------------------+
  3. | '2015-2-1' - '2015-1-1' |
  4. +-------------------------+
  5. | 0 |
  6. +-------------------------+
  7. 1 row in set, 2 warnings (0.00 sec)

以上相当于2015-2015=0

mysql当字符串进行大小比较的时候

  1. mysql> select '2015-2-1' > '2015-1-1';
  2. +-------------------------+
  3. | '2015-2-1' > '2015-1-1' |
  4. +-------------------------+
  5. | 1 |
  6. +-------------------------+
  7. 1 row in set (0.00 sec)
  1. mysql> select '2015-2-1' < '2015-1-1';
  2. +-------------------------+
  3. | '2015-2-1' < '2015-1-1' |
  4. +-------------------------+
  5. | 0 |
  6. +-------------------------+
  7. 1 row in set (0.00 sec)

在这里非常奇怪,'2015-2-1' - '2015-1-1' = 0,为什么大小比较的时候会有大小之分呢?

原来对于数字与非数字混合的字符串,在进行大小比较的时候,如果两字符串长度相等,那么两字符串就会比较相同位置的字符,比较时若字符是数字,则直接比较,若字符是非数字那么会转换为ascii码进行比较,若在某位置上已经有大小之分,那么就不会再进行比较。

  1. mysql> select '2017-03-20 15:27:49' > '2017-03-20 15:27:48';
  2. +-----------------------------------------------+
  3. | '2017-03-20 15:27:49' > '2017-03-20 15:27:48' |
  4. +-----------------------------------------------+
  5. | 1 |
  6. +-----------------------------------------------+
  7. 1 row in set (0.00 sec)

看起来像日期的字符串可以用date_format函数提取当中的年月日,看如下:

  1. 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') 日;
  2. +------+------+------+
  3. | | | |
  4. +------+------+------+
  5. | 2017 | 3 | 20 |
  6. +------+------+------+
  7. 1 row in set (0.00 sec)

非数字字符在比较大小的时候,就例如:

  1. mysql> select 'a' < 'b';
  2. +-----------+
  3. | 'a' < 'b' |
  4. +-----------+
  5. | 1 |
  6. +-----------+
  7. 1 row in set (0.00 sec)

当中的字母会转成ascii码,再进行比较,以上是单字母字符串比较,如果是多字母数字混合字符串比较呢?

  1. mysql> select '1c' > 'bc';
  2. +-------------+
  3. | '1c' > 'bc' |
  4. +-------------+
  5. | 0 |
  6. +-------------+
  7. 1 row in set (0.00 sec)
  1. mysql> select '1yz' > 'abc999';
  2. +------------------+
  3. | '1yz' > 'abc999' |
  4. +------------------+
  5. | 0 |
  6. +------------------+
  7. 1 row in set (0.00 sec)

其实从上面的结果大概可以猜测得到,为让解释更清晰更有说服力,再看下图:

  1. mysql> select ascii('1c'),ascii('bc');
  2. +-------------+-------------+
  3. | ascii('1c') | ascii('bc') |
  4. +-------------+-------------+
  5. | 49 | 98 |
  6. +-------------+-------------+
  7. 1 row in set (0.00 sec)
  1. mysql> select ascii('1yz'),ascii('abc999');
  2. +--------------+-----------------+
  3. | ascii('1yz') | ascii('abc999') |
  4. +--------------+-----------------+
  5. | 49 | 97 |
  6. +--------------+-----------------+
  7. 1 row in set (0.00 sec)

字符串大小比较的时候,会从左向右将两个字符串第一个不相等的两个字符的ascii码的比较结果作为最终结果

MySQL字符串进行加减乘除的运算的更多相关文章

  1. java 对一个字符串进行加减乘除的运算

    记录一个小程序,里面涉及到的JAVA知识点有:字符串扫描,list删除元素的方法,泛型的使用,JAVA中的/要注意的事项.有兴趣的可以看看 package com.demo; import java. ...

  2. MySQL 字符串截取函数

    MySQL 字符串截取函数:left(), right(), substring(), substring_index().还有 mid(), substr().其中,mid(), substr() ...

  3. MySQL字符串函数:字符串截取

    MySQL 字符串截取函数:left(), right(), substring(), substring_index().还有 mid(), substr().其中,mid(), substr() ...

  4. Mysql字符串字段判断是否包含某个字符串的3种方法

    方法一: SELECT * FROM users WHERE emails like "%b@email.com%"; 方法二: 利用MySQL 字符串函数 find_in_set ...

  5. MySQL字符串函数substring:字符串截取

    MySQL 字符串截取函数:left(), right(), substring(), substring_index().还有 mid(), substr().其中,mid(), substr() ...

  6. MySQL字符串转日期类型

    MySQL字符串转日期类型 select str_to_date('2014-08-20 00:00:00', '%Y-%m-%d %H:%i:%s'); >2014-08-20 00:00:0 ...

  7. mysql字符串截取

    mysql字符串截取 update zcat ) where lev1 is null; update zcat ) where lev2 is null; 函数: 1.从左开始截取字符串 left( ...

  8. MySQL 字符串截取相关函数

    MySQL 字符串截取相关函数 在工作中,可能需要将某些字段按某个分割符组成一个字符串作为字段值存取到数据库表中,比如某个任务对应三个结果,分别存储在不同的数据表中,这时可以将这三个不同表的主键按照约 ...

  9. MySQL字符串函数

    字符串大写和小写转换 MySQL 字符串大写和小写转化函数有两对: lower(), uppper() 和 lcase(), ucase() mysql> select lower('DDD') ...

随机推荐

  1. php设计模式--面向对象编程规范PSR

    php业界提出大家要遵循的面向对象编码规范,下面一一列出. PSR-0: 1.命名空间必须与绝对路径一致 2.类的首字母必须大写 3.出入口文件外,其他‘.php’必须只有一个类 PSR-1:基础编码 ...

  2. 详解Vue Native

    译者按: 一家叫GeekyAnts的印度公司开发了Vue Native,基于React Native实现. 原文: Introducing Vue Native 译者: Fundebug 为了保证可读 ...

  3. vue 如何点击按钮返回上一页

    1,vue 如何点击按钮返回上一页呢? 这是vue挂载的范围html代码 <div @click="goOff()">返回</div> 下面是点击返回的方法 ...

  4. 好吧,CSS3 3D transform变换,不过如此!——张鑫旭

    一.写在前面的秋裤 早在去年的去年,我就大肆介绍了2D transform相关内容.看过海贼王的都知道,带D的家伙都不是好惹的,2D我辈尚可以应付,3D的话,呵呵,估计我等早就在千里之外被其霸气震晕了 ...

  5. 常用的String原型

    对于常用的字符串原型的举例 在字符串末尾追加字符串 String.prototype.append = function (str) { return this.concat(str);} 删除指定索 ...

  6. arcgis api 3.x for js 入门开发系列十三地图最短路径分析(附源码下载)

    前言 关于本篇功能实现用到的 api 涉及类看不懂的,请参照 esri 官网的 arcgis api 3.x for js:esri 官网 api,里面详细的介绍 arcgis api 3.x 各个类 ...

  7. iOS----------UITextField实现过滤选中状态拼音

    2018年上班的第二天,就这样背了一个大锅.我们项目中有一个搜索功能,在这一期的版本中,为了增强优化,去除了过滤空格的请求,这样或许能增加很好的用户体验,恰恰相反,偷鸡不成蚀把米.没想到苹果系统的输入 ...

  8. 一个「学渣」从零开始的Web前端自学之路

    从 13 年专科毕业开始,一路跌跌撞撞走了很多弯路,做过餐厅服务员,进过工厂干过流水线,做过客服,干过电话销售可以说经历相当的“丰富”. 最后的机缘巧合下,走上了前端开发之路,作为一个非计算机专业且低 ...

  9. centos6.5上进行crontab操作

    1.service crond start 2. vi  /home/cron.ini */ * * * * /home/monitor.sh 3.crontab  /home/cron.ini OK

  10. Elixir 简介

    概述 Elixir 是一种基于 Erlang 虚拟机的函数式,面向并行的通用语言, 它是一门通用语言,所以不仅可以用在擅长的高可用,高并发场景下,也可以用在 web 开发等场景下. Erlang 诞生 ...