mysql中string和number的转换问题怎么解决
导读:本文共1736字符,通常情况下阅读需要6分钟。同时您也可以点击右侧朗读,来听本文内容。按键盘←(左) →(右) 方向键可以翻页。
摘要: mysql中string和number的转换今天无意中发现一个很奇怪的现象,在写sql语句的时候,想筛选列值为空字符串的记录,结果把列值为0的记录也一起筛选出来了总结原因如下当非同类型比较,等号两边分别为number和string之一时候,mysql会把string类型和number类型进行转换:(1)数值型字符串如''、'string&... ...
目录
(为您整理了一些要点),点击可以直达。今天无意中发现一个很奇怪的现象,在写sql语句的时候,想筛选列值为空字符串的记录,结果把列值为0的记录也一起筛选出来了
当非同类型比较,等号两边分别为number和string之一时候,mysql会把string类型和number类型进行转换:
如''、'string'、'abc'等,会转换成0
eg:
如'123string'、'0123string'等,会取头部类型进行转换
eg:
如'string123'、'string0123'等,会取头部类型进行转换
eg:
如'123'->123、'023'->23等
eg:
eg:
所以针对我遇到的问题,mysql把''当成字符串处理,转换成了0,0=0,所以把列值为0的记录也一并筛选了出来
+号的处理方式同理:
如果+号两边类型不一致,则把string转换成number处理
然后这串数字就能变为16进制字符串,只需要加上0x的前缀!
UNHEX(‘14’) – 每对十六进制数字转化为一个字符。
UNHEX(‘14’),对应 SI, 该字符无法正确输出
但是ORDER BY UNHEX(‘14’) 是可以的。
mysql中string和number的转换问题怎么解决的详细内容,希望对您有所帮助,信息来源于网络。