全球主机交流论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

CeraNetworks网络延迟测速工具IP归属甄别会员请立即修改密码
查看: 910|回复: 9
打印 上一主题 下一主题

mysql怎么判断记录是否存在

[复制链接]
跳转到指定楼层
1#
发表于 2016-3-31 09:11:17 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 muyang 于 2016-3-31 09:12 编辑


大牛路过帮看一下,怎么判断记录是否存在,要那种比较节省资源的写法……

(在php文件里判断,大牛来个整体代码)



2#
发表于 2016-3-31 09:16:09 | 只看该作者
只给思路自己去写
SELECT `索引` FORM `xxx表` WHERE `xx`= 'xx' limit 1;
取记录数咯 大于0 有
3#
发表于 2016-3-31 09:28:01 | 只看该作者
SELECT count(*)  这样快一点
4#
发表于 2016-3-31 09:28:45 | 只看该作者
本帖最后由 0000000 于 2016-3-31 09:30 编辑

SELECT count() 要统计总数 楼主是要判断某条数据存不存在. 而且统计总数 不比找一条记录速度快  
5#
 楼主| 发表于 2016-3-31 09:32:41 | 只看该作者
0000000 发表于 2016-3-31 09:28
SELECT count() 要统计总数 楼主是要判断某条数据存不存在. 而且统计总数 不比找一条记录速度快   ...

count(`索引`) 这东西是不是会把整个列的所有记录统计一下?那样的话是不是比较浪费资源呢
6#
发表于 2016-3-31 09:42:35 | 只看该作者
muyang 发表于 2016-3-31 09:32
count(`索引`) 这东西是不是会把整个列的所有记录统计一下?那样的话是不是比较浪费资源呢 ...

所以直接按条件 select 一个索引返回一条数据 就行了
7#
 楼主| 发表于 2016-3-31 09:50:07 | 只看该作者
0000000 发表于 2016-3-31 09:16
只给思路自己去写
SELECT `索引` FORM `xxx表` WHERE `xx`= 'xx' limit 1;
取记录数咯 大于0 有 ...

如果有一千万的记录数据,比如要判断的记录,在9百万行的位置

这段代码,会不会从第一行开始检查,一直查到9百万行才停?
8#
发表于 2016-3-31 10:13:56 | 只看该作者
select字段 是最慢的
建议还是优化表  加唯一索引 杜绝引起重复的可能
9#
发表于 2016-3-31 10:43:27 来自手机 | 只看该作者
首先你得有1000万行不同的数据
10#
发表于 2016-3-31 11:22:45 | 只看该作者
muyang 发表于 2016-3-31 09:50
如果有一千万的记录数据,比如要判断的记录,在9百万行的位置

这段代码,会不会从第一行开始检查,一直 ...

limit 1不会
2就会
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|全球主机交流论坛

GMT+8, 2025-10-31 05:18 , Processed in 0.303696 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表