首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【坑】 MySQL中,字符串和数值的比较

官方文档:https://dev.mysql.com/doc/refman/5.7/en/comparison-operators.html 原文: Comparison operations result...也就是说在比较的时候,String是可能会被转为数字的。 对于数据开头的字符串,转成数字后会自动丢弃后面的字母部分,只留下纯数字进行比较。...对于没有数字的那些字符串,与数值进行比较的时候,就只剩下0去和其他数值进行比较了。 例子: 1、对于没有数字的那些字符串,与数值进行比较的时候,就只剩下0去和其他数值进行比较了。...abc' | +---------+------+-----------------------------------------+ 1 row in set (0.00 sec) 2、对于数据开头的字符串...其实字符串和数值比较最大的坑在于:它会导致查询不能用到索引,直接就影响了查询的效率。

2.1K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL中字符串比较函数学习--MySql语法

    若已经对一个字符串函数给定一个二进制字符串作为参数, 则所得到的结果字符串也是一个二进制字符串。一个转化为字符串的数字被作为二进制字符串对待。这仅会对比较结果产生影响。...一般而言, 若字符串比较中任意一个表达式是区分大小写的,则执行比较时也区分大小写。 expr LIKE pat [ESCAPE 'escape-char'] 模式匹配,使用SQL简单正规表达式比较。...以下两个语句举例说明了字符串比较不区分大小写,除非其中一个操作数为二进制字符串: mysql> SELECT 'abc' LIKE 'ABC'; -> 1 mysql> SELECT '...注释:由于在字符串中, MySQL使用 C 转义语法 (例如, 用‘\n’来代表换行字符 ),在REGEXP字符串中必须将用到的‘\’ 双写。...这使得默认的比较区分大小写,当操作数中的一个或两个都是二进制字符串时除外。

    1.9K30

    MySQL和Oracle字符串截取函数用法总结(比较)

    点击上方'伦少的博客'关注与您一起成长 前言 本文总结MySQL和Oracle的字符串截取函数的用法 工作中MySQL和Oracle都用,有时会碰到两种数据库SQL用法的不同,就会上网查一下,但是时间久了...下面等价 SELECT SUBSTRING('Hello World',6,20); SELECT SUBSTRING('Hello World' FROM 6 FOR 20); 可通过LENGTH查看字符串的长度验证...,下面仅总结length length>0时返回length个字符数,当length>string的可截取的长度时,只返回可截取的长度,这点和MySQL相同 SELECT SUBSTR('Hello World...SELECT SUBSTR('Hello World',1,0) FROM DUAL; SELECT SUBSTR('Hello World',6,-20) FROM DUAL; [NULL] 3 比较总结...最后比较一下MySQL和Oracle的不同 1、 MySQL函数为SUBSTRING 或 SUBSTR,Oracle只有SUBSTR 2、 position=0时MySQL返回空,而Oracle和position

    1.1K40

    Mysql中varchar字符串的比较,swoole预处理参数绑定

    类似select * from sheets where s_status > 3 分析 php调用时条件传的是数字类型 组件生成的SQL语句直接执行正常 排查 打开了mysql的运行日志,分析到最终运行的...解决有两条路 mysql的字段类型改为数字 研究swoole的参数预处理问题,可以测试普通PHP的预处理是否也有问题 能学习的点 字符串类型字段的比较规则 mysql中字符串类型字段的比较规则 找了一圈资料...,相关文章比较少,终于在比较不起眼的角落里找到资料。...字符串比较 是根据ascii码比较 只有当第一个字符相同才对比第二个字符。以此类推。...执行 我筛选>3应该是2条结果都有,但是程序运行只能得到1条结果: id = 1的数据 那么我们上面说到 字符串的比较规则,从第一个字符开始比较,只有第一个字符相等 才会比较第二个字符… ‘4’ >

    1.5K20

    Tcl的字符串操作:比较字符串

    上期内容:Tcl的字符串操作:获取字符 在Tcl中,可利用stringcompare命令对字符串进行比较。该命令需要接收两个字符串参数。...string equal则是对两个字符串进行简单的比较,如两者严格相同,则返回1,否则返回0(与stringcompare的返回值是不同的),如下图所示。 ?...还可以通过-length选项指定对字符串的前length个字符进行比较操作,如下图所示。这里可以看到-length的在命令中的正确位置。 ?...尽管字符串比较支持直接使用数学表达式(> 、的角度而言,string compare和string equal更为高效。...和-length选项 -尽管字符串比较支持直接使用数学符合,但使用上述两个命令更为高效 如果文章对你有收获,欢迎转发~

    2.8K40

    比较含退格的字符串!

    844.比较含退格的字符串 力扣题目链接:https://leetcode-cn.com/problems/backspace-string-compare 给定 S 和 T 两个字符串,当它们分别被输入到空白的文本编辑器后...那么本题,确实可以使用栈的思路,但是没有必要使用栈,因为最后比较的时候还要比较栈里的元素,有点麻烦。...这里直接使用字符串string,来作为栈,末尾添加和弹出,string都有相应的接口,最后比较的时候,只要比较两个字符串就可以了,比比较栈里的元素方便一些。...动画如下: 如果S[i]和S[j]不相同返回false,如果有一个指针(i或者j)先走到的字符串头部位置,也返回false。...arrT.pop() : arrT.push(char); } return arrS.join('') === arrT.join(''); // 比较两个字符串是否相等 }; //

    3K30

    JavaScript字符串间的比较

    @雪斌在JavaScript中的字符串操作一文中讲的很详细,但是对于涉及Js字符串的比较,还是有必要再学习和探究下的。...字符串和其他对象比较大小 字符串和其他对象进行比较,大体要遵循下面的这些考量: 两个操作数都是数值,则进行数值比较 两个操作数都是字符串,则比较两个字符串对应的字符编码值 两个操作数有一个是数值,则将另一个转换为数值...alert("的".charCodeAt());//30340 alert("我"的");//true,汉字比较,转成ascii码 5)当数字和字符串比较,且字符串为数字。.../49 6)当数字和字符串比较,且字符串为非纯数字时,则将非数字字符串转成数字的时候会转换为NaN,当NaN和数字比较时不论大小都返回false(NaN “Not a Number”。...,则通过Number()函数将字符串转换为数值 如果一个操作值是对象,另一个不是,则调用对象的valueOf()方法,得到的结果按照前面的规则进行比较 null与undefined是相等的;avaScript

    9.4K90

    MySQL 中不要拿字符串类型的字段直接与数字进行比较

    后来经过排查,发现在 MySQL 查询中,'abc' 和 '0' 比较结果显然是不等的,但如果 'abc' 和 0 比较呢?结果居然是相等的。...在 MySQL 官方文档中关于比较的章节中: Strings are automatically converted to numbers and numbers to strings as necessary...也就是说:在比较的时候,字符串和数字进行对比是可能会被转为数字的,具体来说: 对于数字开头的字符串来说,转为数字的结果就是截取前面的数字部分,比如 '123abc' 会被转换成 123。...而对于开头部分不能截取出数字的字符串来说,转换的结果自然就是 0 了,所以结果就是就等于数字0了。...要和字符串 '0' 进行对比,千万要记得。

    1.6K20

    mysql 字段时间类型的比较

    直接使用四位数字或字符串,范围是1901-2155,输入的格式为’YYYY’或YYYY,如输入‘2011’或2011就回直接保存为2011,若超过范围就会表示为0000 使用两位的字符串表示,如果插入为...-69则表示为2000-2069,若插入70-99则表示为1970-1999.如输入22保存为2222,输入88保存为1988.如果是0则表示为0000.注意该处和字符串的情况不一样 TIME 该类型表示时...:分:秒,尽管时间范围为0~23,但是为了表示某些特殊的时间,mysql将小时的范围扩大了,并且支持负值。....我们可以通过获取当前的值 DATE 该类型表示年-月-日,标准格式为,但是中还支持一些不严谨的格式:比如等其他的符号来分割 在插入数据的数据的也可以使用 年份的转换和上面的类型的规则一样的 可以使用...哈哈,到年后就别用这个类型了 这只是一个简单的区分说明,具体时间类型的说明 请参考 官方文档 https://dev.mysql.com/doc/refman/5.7/en/date-and-time-types.html

    4.7K80

    c语言中字符串比较的库函数是什么_c语言比较字符串大小

    通过字符串的每一位依次比较,这样的比较方式,就可以判断出字符串相等。...通过右侧的观察窗口可以看到,此时*s1和*s2的内容是”a”,而不是整个字符串的内容。说明这行代码比较的是字符串的第一个字符,而不是整个字符串。那么要比较整个内容的话,还得每个字符挨个比较。...通过上面的分析可能会有一个疑问,为什么用”==”运算符比较单个字符的时候比较的就是内容,而比较字符串的时候,比较的却是地址?...这个函数其实就是相当于把上面例程中对字符串每个字符独立比较方法的一个封装,内部函数实现方式类似于下面这样。 由于字符串在C语言中的处理比较特殊,所以C语言提供了一个专门操作字符串的库。...,通过数组的下标去调用不同的字符串,然后使用字符串比较函数去判断字符串,这样switch语句的分支判断就可以转换为字符串的下标。

    2K30

    LeetCode 844 比较含退格的字符串

    LeetCode 844 比较含退格的字符串 力扣 844 比较含退格的字符串 | LeetCode 844 Backspace String Compare | 算尽天下系列第 11 期 | 栈/双指针...算法与数据结构 栈 双指针 题解 这道题可以用一个栈来模拟退格的操作,遍历字符串,遇到新字符就入栈,遇到退格键就出栈,最后比较两个栈内的元素是否相等,非常简单。...从前往后遍历字符串的时候,遇到一个字符,我们是没有办法知道这个字符最终会不会属于这个字符串,因为我们没有办法知道后面会有多少个退格,但是从后往前遍历字符串的时候,我们有办法知道一个字符是不是属于这个字符串...那么,我们可以从后往前遍历字符串,记 i 和 j 分别表示当前两个字符串的比较位置,初始均为 strlen() - 1。 若当前位置的字符不相等(S[i] !...= T[j]),则直接 return false 而无需继续往前比较,若当前位置的字符相等,那么继续往前比较。 现在还需要处理一个退格的问题。

    59141

    浅谈Java字符串的截取和分割、比较字符串

    这篇文章我们浅谈Java字符串的截取和分割、比较字符串和switch语句支持字符串类型知识。...二、比较字符串的”==”和”equal()”区别 1.equal()方法是比较两个字符串中的字符是否相等,==方法是用来比较两个字符串中对象的地址是否一致。...三、switch语句支持字符串类型 1.在程序开发中,对字符串的操作中使用比较多,所以在JDK7新特性出现Java编程的方便。...四、总结 本文主要介绍了字符串的截取和分割、比较字符串的”==”和”equal()”区别、switch语句支持字符串类型的知识点,字符串的截取和分割介绍了一些方法,也通过案例理解这个用法。...详细的介绍比较字符串的”==”和”equal()”区别,理解这两个的区别。switch语句支持字符串类型,在程序开发中,对字符串的操作中使用比较多,所以在JDK7新特性出现Java编程的方便。

    2K20

    【Python】数据容器总结 ② ( 数据容器元素排序 | 字符串大小比较 | 字符大小比较 | 长短一样的字符串大小比较 | 长短不一样的字符串大小比较 )

    1、字符大小比较 字符 大小的比较 , 是通过 字符 在 ASCII 码表中的 对应 数字 进行比较的 ; 2、长短一样的字符串大小比较 字符串 之间的比较 是按位 进行比较 , 只要有一位大 ,...那么整个字符串就大 ; 这里以 “abc” 与 “abd” 字符串比较为例 : 先比较第一位 , 都是 a , 相等 ; 再比较第二位 , 都是 b , 相等 ; 最后比较第三位 , 第一个字符串是 c...""" result = "abc" > "abd" print(result) # False 执行结果 : False 3、长短不一样的字符串大小比较 如果长短不一样的字符串大小进行比较 ,...也是按位进行比较 , 有字符的位比没有字符的位要大 ; 举例说明 : “a” 与 “ab” 进行比较 ; 先比较第一位 , 都是 a , 相等 ; 再比较第二位 , 第一个字符串只有一位 , 第二位是空的..., 第二个字符串第二位是 b , 显然 b 大于空的字符 , 这里第二个字符串大于第一个字符串 ; 代码示例 : """ 字符串比较 代码示例 """ result = "a" > "ab" print

    17930

    java学习之路:15.对象的创建,属性,行为,引用,比较,销毁

    每个对象都是相互独立的,在内存中占据独立的内存地址,并且每个对象都具有自己的生命周期,当一个对象的生命周期结束时,对象就变成垃圾,由java虚拟机自带的垃圾回收机制处理,不能再被使用。...2.访问对象的属性和行为 创建出对象后,可以使用对象.类成员来获取对象的属性和行为,也就是成员变量和成员方法,这些在前文提到过。所以对象获取类成员就是获取属性和行为。...通过结果,我们可以很好的证明每个对象是独立的,我们改变了book1中i的值,但是boo2中的i值还是原来的。...4.对象的比较 Java语言中有两种对象的比较方法,分别为“==”运算符和equals()方法。...equals()方法是String类中的方法,它用于比较两个对象引用所指的内容是否相等 而”==“运算符比较的是两个对象引用的地址是否相等。

    71231
    领券