找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 97|回复: 9

mysql怎么判断记录是否存在

[复制链接]

154

主题

308

回帖

1138

积分

金牌会员

积分
1138
发表于 2016-3-31 09:11:17 | 显示全部楼层 |阅读模式
本帖最后由 muyang 于 2016-3-31 09:12 编辑


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

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



回复

使用道具 举报

6

主题

346

回帖

726

积分

高级会员

积分
726
发表于 2016-3-31 09:16:09 | 显示全部楼层
只给思路自己去写
SELECT `索引` FORM `xxx表` WHERE `xx`= 'xx' limit 1;
取记录数咯 大于0 有
回复

使用道具 举报

190

主题

629

回帖

1852

积分

金牌会员

积分
1852
发表于 2016-3-31 09:28:01 | 显示全部楼层
SELECT count(*)  这样快一点
回复

使用道具 举报

6

主题

346

回帖

726

积分

高级会员

积分
726
发表于 2016-3-31 09:28:45 | 显示全部楼层
本帖最后由 0000000 于 2016-3-31 09:30 编辑

SELECT count() 要统计总数 楼主是要判断某条数据存不存在. 而且统计总数 不比找一条记录速度快  
回复

使用道具 举报

154

主题

308

回帖

1138

积分

金牌会员

积分
1138
 楼主| 发表于 2016-3-31 09:32:41 | 显示全部楼层

0000000 发表于 2016-3-31 09:28

SELECT count() 要统计总数 楼主是要判断某条数据存不存在. 而且统计总数 不比找一条记录速度快   ...

count(`索引`) 这东西是不是会把整个列的所有记录统计一下?那样的话是不是比较浪费资源呢
回复

使用道具 举报

6

主题

346

回帖

726

积分

高级会员

积分
726
发表于 2016-3-31 09:28:00 | 显示全部楼层

muyang 发表于 2016-3-31 09:32

count(`索引`) 这东西是不是会把整个列的所有记录统计一下?那样的话是不是比较浪费资源呢 ...

所以直接按条件 select 一个索引返回一条数据 就行了
回复

使用道具 举报

154

主题

308

回帖

1138

积分

金牌会员

积分
1138
 楼主| 发表于 2016-3-31 09:42:35 | 显示全部楼层

0000000 发表于 2016-3-31 09:16

只给思路自己去写
SELECT `索引` FORM `xxx表` WHERE `xx`= 'xx' limit 1;
取记录数咯 大于0 有 ...

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

这段代码,会不会从第一行开始检查,一直查到9百万行才停?
回复

使用道具 举报

4

主题

112

回帖

240

积分

中级会员

积分
240
发表于 2016-3-31 09:32:00 | 显示全部楼层
select字段 是最慢的
建议还是优化表  加唯一索引 杜绝引起重复的可能
回复

使用道具 举报

3

主题

108

回帖

231

积分

中级会员

积分
231
发表于 2016-3-31 09:50:07 | 显示全部楼层
首先你得有1000万行不同的数据
回复

使用道具 举报

1

主题

36

回帖

79

积分

注册会员

积分
79
发表于 2016-3-31 09:16:00 | 显示全部楼层

muyang 发表于 2016-3-31 09:50

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

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

limit 1不会
2就会
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|Discuz! X

GMT+8, 2025-2-3 01:03 , Processed in 0.021804 second(s), 3 queries , Gzip On, Redis On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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