mysql字符串内部是怎么比较大小的

首页 / 常见问题 / 低代码开发 / mysql字符串内部是怎么比较大小的
作者:低代码工具 发布时间:2025-05-15 09:44 浏览量:6890
logo
织信企业级低代码开发平台
提供表单、流程、仪表盘、API等功能,非IT用户可通过设计表单来收集数据,设计流程来进行业务协作,使用仪表盘来进行数据分析与展示,IT用户可通过API集成第三方系统平台数据。
免费试用

在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)。

数据库是一整套数据管理体系,包括数据存储的模型、数据组织的架构、数据分析的算法、数据管理的工具以及数据访问的接口等等。

最后建议,企业在引入信息化系统初期,切记要合理有效地运用好工具,这样一来不仅可以让公司业务高效地运行,还能最大程度保证团队目标的达成。同时还能大幅缩短系统开发和部署的时间成本。特别是有特定需求功能需要定制化的企业,可以采用我们公司自研的企业级低代码平台织信Informat。 织信平台基于数据模型优先的设计理念,提供大量标准化的组件,内置AI助手、组件设计器、自动化(图形化编程)、脚本、工作流引擎(BPMN2.0)、自定义API、表单设计器、权限、仪表盘等功能,能帮助企业构建高度复杂核心的数字化系统。如ERP、MES、CRM、PLM、SCM、WMS、项目管理、流程管理等多个应用场景,全面助力企业落地国产化/信息化/数字化转型战略目标。 版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们微信:Informat_5 处理,核实后本网站将在24小时内删除。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系邮箱:hopper@cornerstone365.cn 处理,核实后本网站将在24小时内删除。

最近更新

低代码平台优缺点分析
09-10 11:56
河东自助建站怎么样?2023年实测解析低代码建站的核心优势与用户评价
09-10 11:56
低代码平台盈利模式解析
09-10 11:56
java开源低代码平台推荐
09-10 11:56
免费低代码平台有哪些推荐
09-10 11:56
低代码开发是什么意思
09-10 11:56
低代码平台入门教程
09-10 11:56
低代码平台开源案例解析
09-10 11:56
国产十大低代码平台对比
09-10 11:56

立即开启你的数字化管理

用心为每一位用户提供专业的数字化解决方案及业务咨询

  • 深圳市基石协作科技有限公司
  • 地址:深圳市南山区科发路8号金融基地1栋5F5
  • 手机:137-1379-6908
  • 电话:0755-86660062
  • 邮箱:sales@cornerstone365.cn
  • 微信公众号二维码

© copyright 2019-2025. 织信INFORMAT 深圳市基石协作科技有限公司 版权所有 | 粤ICP备15078182号

前往Gitee仓库
微信公众号二维码
咨询织信数字化顾问获取最新资料
客服咨询热线1
0755-86660062
客服咨询热线2
137-1379-6908
申请预约演示
立即与行业专家交流