求解 Mysql 这样的字段是怎么判断的呢

2019-10-30 17:51:45 +08:00
 claysec

我们进行验证密码的时候最常用的方法是 “=” 列入

SELECT * FROM admin WHERE name = 'admin' and password = "123456"

假设现在用 < 或者 > 在 password 字段进行判断会出现很奇怪的结果。 https://i.imgur.com/BMugQCK.png

1 不行,大于 2 就可以了。小弟不知道他是怎么判断的。一直没有搞懂。 这是我的数据库 Imgur

求大神帮忙

2383 次点击
所在节点    程序员
25 条回复
claysec
2019-10-31 09:33:28 +08:00
@laminux29 那你想要我表达什么呢?
claysec
2019-10-31 09:34:42 +08:00
@taogen 11 楼是答案。已经弄明白了(滑稽
a7217107
2019-10-31 09:41:31 +08:00
跟字符串长度无关,比较的是字符串的编码,可能是 Unicode (因为有中文),从首位开始比较,相同则比较下一位,不同则返回对应的 true or false
silenceeeee
2019-10-31 09:47:43 +08:00
google mysql collate
claysec
2019-10-31 13:31:25 +08:00
@a7217107 比的是 ascii 码。#16 已经很清楚啦

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/614567

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX