我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mysql中string和number的转换问题怎么解决

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mysql中string和number的转换问题怎么解决

本篇内容介绍了“mysql中string和number的转换问题怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

mysql中string和number的转换

今天无意中发现一个很奇怪的现象,在写sql语句的时候,想筛选列值为空字符串的记录,结果把列值为0的记录也一起筛选出来了

总结原因如下

当非同类型比较,等号两边分别为number和string之一时候,mysql会把string类型和number类型进行转换:

(1)数值型字符串

如''、'string'、'abc'等,会转换成0

eg:

select '' = 0 from dual;   ---结果:1select 'a' = 0 from dual;   ---结果:1
(2)number和string拼接字符串

如'123string'、'0123string'等,会取头部类型进行转换

eg:

select '123abc' = 0 from dual;   ---结果:0select '123abc' = 123 from dual;   ---结果:1select '0123abc' = 123 from dual;   ---结果:1select '123abc' + '23def' from dual;   ---结果:146
(3)string和number拼接字符串

如'string123'、'string0123'等,会取头部类型进行转换

eg:

select 'abc123' = 0 from dual;   ---结果:1select 'abc123' = 123 from dual;   ---结果:0select 'abc123' + 'def45' from dual;   ---结果:0
(4)数值型字符串则会转换成相应的number

如'123'->123、'023'->23等

eg:

select '123' = 0 from dual;   ---结果:0select '123' = 123 from dual;   ---结果:1select '0123' = 123 from dual;   ---结果:1
(5)number则直接转换成对应的string

eg:

select 123 = '123' from dual;   ---结果:1

所以针对我遇到的问题,mysql把''当成字符串处理,转换成了0,0=0,所以把列值为0的记录也一并筛选了出来

+号的处理方式同理:

如果+号两边类型不一致,则把string转换成number处理

select '0string' + 0 = 'string' from dual;   ---结果:1   '0string' + 0 -> 0 + 0 = 0,0和'string'进行比较select 'string' = 'string' + 0 from dual;   ---结果:1   'string' + 0 -> 0 + 0 = 0,'string'和0进行比较select 'string' + 0 = 'string' + 0 from dual;   ---结果:1   'string' + 0 -> 0 + 0 ,0和0进行比较select 'string' + 0 = 'string' + 1 from dual;   ---结果:0   'string' + 0 -> 0 + 0 ,'string' + 1 -> 0 + 1,0和1进行比较

mysql中hex、varchar、number相互转换

hex(‘20')= 14select HEX(20) from DUAL – result: 14

然后这串数字就能变为16进制字符串,只需要加上0x的前缀!

  • UNHEX(‘14’) – 每对十六进制数字转化为一个字符。

  • UNHEX(‘14’),对应 SI, 该字符无法正确输出

但是ORDER BY UNHEX(‘14’) 是可以的。

“mysql中string和number的转换问题怎么解决”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mysql中string和number的转换问题怎么解决

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql中string和number的转换问题怎么解决

本篇内容介绍了“mysql中string和number的转换问题怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!mysql中strin
2023-07-02

关于mysql中string和number的转换问题

目录mysql中string和number的转换总结原因如下(1)数值型字符串(2)number和string拼接字符串(3)string和number拼接字符串(4)数值型字符串则会转换成相应的number(5)number则直接转换成对
2022-06-13

JSON各种转换问题怎么解决

这篇文章主要讲解了“JSON各种转换问题怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JSON各种转换问题怎么解决”吧!首先引入jar包:
2023-07-05

numpy强制类型转换的问题怎么解决

本篇内容主要讲解“numpy强制类型转换的问题怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“numpy强制类型转换的问题怎么解决”吧!numpy强制类型转换今天用numpy遇到一个关于类
2023-06-30

C++中vector和数组之间的转换及其效率问题怎么解决

本文小编为大家详细介绍“C++中vector和数组之间的转换及其效率问题怎么解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“C++中vector和数组之间的转换及其效率问题怎么解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一
2023-07-05

mysql中的filesort问题怎么解决

在MySQL中,filesort是指MySQL使用文件进行排序操作。通常情况下,filesort是由于MySQL无法使用索引进行排序而导致的,可能是因为查询语句中没有合适的索引,或者索引失效等原因。解决filesort问题的方法有以下几种
mysql中的filesort问题怎么解决
2024-05-22

MySQL索引失效后隐式转换的问题这么解决

MySQL索引失效后隐式转换的问题这么解决,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。常见索引失效:1. 条件索引字段"不干净":函数操作、运算操作2. 隐式类型转换:字
2023-06-26

php中浮点数转换出现的常见问题怎么解决

本篇内容介绍了“php中浮点数转换出现的常见问题怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、浮点数的表示在计算机中,浮点数是由
2023-07-05

数据转换中的Python问题及解决方法

数据转换中的Python问题及解决方法在日常工作中,我们经常会遇到需要对数据进行转换的情况,无论是从一个数据结构到另一个数据结构的转换,还是对数据进行格式转换或者数据清洗,Python是一种强大而灵活的编程语言,提供了丰富的库和工具来处理这
2023-10-22

怎样帮助解决大数据转换和管理问题

今天就跟大家聊聊有关怎样帮助解决大数据转换和管理问题,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。  尽管大数据分析技术取得了惊人的进步,但我们在很大程度上仍需要手动来完成重要任务,
2023-06-02

Python的文本文件转换编码问题怎么解决

这篇文章主要介绍“Python的文本文件转换编码问题怎么解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python的文本文件转换编码问题怎么解决”文章能帮助大家解决问题。测试数据注:测试文本采用
2023-07-06

编程热搜

目录