mysql仅查询一条数据时遇到的坑

发布时间:2020-06-05 16:43:59 作者:三月
来源:网络 阅读:1815

下文给大家带来有关mysql仅查询一条数据时遇到的坑内容,相信大家一定看过类似的文章。我们给大家带来的有何不同呢?一起来看看正文部分吧,相信看完mysql仅查询一条数据时遇到的坑你一定会有所收获。

场景:有用户表user,有id,email,user_name,mobile等字段,现在要求根据指定email帐号查询一个用户。

乍一看,这个需求简单,不用考虑直接写出了一下sql

select * from user where email='xxx@yyy.com';

这时,就有可能踩雷了。

分析一下这个雷区,存在以下几种情形:

这种情况下,就悲剧了。由于没有索引,即使email的记录不重复,也会全表扫描。

解决方案

在仅查询一条记录的时候,无论where条件是否有索引有什么样的索引,最好在条件后面加limit 1限制一下。这样就能避免全表扫描,尽可能提高查询的效率。养成这样的意识习惯,就不会踩坑。

select * from user where email='xxx@yyy.com' limit 1;

原理:当mysql查询时,如果有limit 1限制,查询到满足条件的第一条记录的就返回结果,不会继续查询下去。

特殊情况

假如email列没有索引,且刚好记录在数据表的最后一条,这样limit 1实际上也会全表扫描,这种情况下就最好考虑给email列加索引。

对于上文关于mysql仅查询一条数据时遇到的坑,大家觉得是自己想要的吗?如果想要了解更多相关,可以继续关注我们的行业资讯板块。

推荐阅读:
  1. hadoop遇到的坑
  2. vue resource post请求时遇到的坑有哪些

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

mysql 查询数据 的坑

上一篇:限制用户通过ssh密钥进行认证登陆

下一篇:nginx实现文件上传和下载

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》