mysql 如何判断 "字符串" 是否为 "数字"

  这个问题有点怪 ,但很多时候我们会以字符串的形式存储数字 , 反过来我们用字符串进行数学运算时, 好像也不会出错 . 除非 , 用作数学运算的字符串不能转换成数字 .
但是我们改如何判断字符串是否能转换成数字呢 ? 

  采用mysql的 REGEXP运算符 . 怎么用?

  {String} REGEXP '[^0-9.]'

  前面的字符串是我们要做判断的, 后面的字符串是mysql的正则表达式,意思是 匹配不是数字或者小数点的字符。

  如果String中含有不是0-9之间的数字或者是小数点时,返回true ,反之则返回false。

  比如说 :

1 select ('123a' REGEXP '[^0-9.]'); --‘123a'中含有字符'a' 输出结果为1 mysql中常量true输出为1 false输出为0

  注意:如果字符串中有空格,也会匹配到正则表达式,返回1。如果是要去掉两端的空格,就要将判断的字符串,就要对字符串使用 trim()函数了。

这个只是REGEXP操作符的简单应用,REGEXP的详细应用请参考官方文档。

  

posted @ 2016-07-16 13:35  Justforcon  阅读(50883)  评论(7编辑  收藏  举报