找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 95|回复: 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

主题

628

回帖

1850

积分

金牌会员

积分
1850
发表于 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

主题

110

回帖

236

积分

中级会员

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

使用道具 举报

3

主题

107

回帖

229

积分

中级会员

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

使用道具 举报

1

主题

35

回帖

77

积分

注册会员

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

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

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

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

limit 1不会
2就会
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-2-3 00:54 , Processed in 0.021021 second(s), 4 queries , Gzip On, Redis On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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