百独托管7500 紫田网络超高转化播放器收cps[推荐]速盾CDN 免实名免备防屏蔽阿里云 爆款特卖9.9元封顶提升alexa、IP流量7Q5团队
【腾讯云】中小企福利专场【腾讯云】多款产品1折起高防 随时退换 好耶数据小飞国外网赚带你月入万元炎黄网络4H4G10M 99每月
香港带宽CN2/美国站群优惠中客数据中心 服务器租用联盟系统移动广告平台 中易企业专场腾讯云服务器2.5折九九数据 工信部正规资质
腾讯云新用户大礼包代金券高价收cpa注册量高价展示【腾讯云】2核2G/9.93起租服务器找45互联 随时退换阿里云 短信服务 验证秒达

[闲聊畅谈] [解决]来问下技术问题,查找当天时间怎么效率最高 [复制链接]
查看:1096 | 回复:7

215

主题

3917

帖子

5543

积分

落伍者(三羊开泰)

Rank: 3Rank: 3

贡献
458
鲜花
47
注册时间
2007-3-29

QQ绑定落伍手机绑定

发表于 2021-4-20 15:10:02 | 显示全部楼层 |阅读模式 来自 中国浙江杭州
本帖最后由 卧草泥马 于 2021-4-20 16:26 编辑

表中两个字段

time1 是int  放的是时间戳
time2 是timestamp格式

而且这两个字段都做了 index索引

数据量大概三千万条

问题就是我查找当天的记录,不管是用time1还是time2,速度都不理想

SELECT count(id) as nums  FROM `AAA` WHERE  date_format(from_UNIXTIME(time1),'%Y-%m-%d') = date_format(now(),'%Y-%m-%d')

或者

SELECT COUNT( id ) AS nums FROM `AAA` WHERE DATEDIFF( time2, NOW( ) ) =0


求个高效的语句,感谢,汇报下结论
===========================
最后用了最直接的查询
$today_start = strtotime(date('Y-m-d 00:00:00'));
$today_end = strtotime(date('Y-m-d 23:59:59'));
SELECT COUNT( id )  FROM `AAA` WHERE time1>$today_start AND time1<$today_end

速度肉眼可见的提升,哈

没站 ,签啥名
回复

使用道具 举报

26

主题

808

帖子

1133

积分

落伍者(两全齐美)

Rank: 2

贡献
835
鲜花
1
注册时间
2005-12-24

落伍手机绑定

发表于 2021-4-20 15:18:56 | 显示全部楼层 来自 中国福建泉州
在SQL中有计算语句好像不好
试下直接的
SELECT count(id) as nums  FROM `AAA` WHERE time1=当天时间戳
回复 支持 反对

使用道具 举报

215

主题

3917

帖子

5543

积分

落伍者(三羊开泰)

Rank: 3Rank: 3

贡献
458
鲜花
47
注册时间
2007-3-29

QQ绑定落伍手机绑定

 楼主| 发表于 2021-4-20 15:40:14 | 显示全部楼层 来自 中国浙江杭州
0度寂寞 发表于 2021-4-20 15:18
在SQL中有计算语句好像不好
试下直接的
SELECT count(id) as nums  FROM `AAA` WHERE time1=当天时间戳

当天时间戳 ?

这个不是很明白
没站 ,签啥名
回复 支持 反对

使用道具 举报

923

主题

5万

帖子

4万

积分

落伍者(四季发财)

你可以侮辱我但不可以侮辱我头像

Rank: 4

贡献
1596
鲜花
72
注册时间
2004-6-14

QQ绑定落伍手机绑定

发表于 2021-4-20 15:43:17 | 显示全部楼层 来自 中国江苏南京
索引做了吗
回复 支持 反对

使用道具 举报

56

主题

2万

帖子

2万

积分

落伍者(四季发财)

Rank: 4

贡献
394
鲜花
16
注册时间
2001-7-30
发表于 2021-4-20 15:47:24 | 显示全部楼层 来自 中国重庆
算出当天的起始时间,然后 time>? and time<?  这样效率最最高

评分

参与人数 1鲜花 +1 收起 理由
卧草泥马 + 1 确实,速度直线提升

查看全部评分

回复 支持 反对

使用道具 举报

51

主题

1801

帖子

3508

积分

落伍者(两全齐美)

Rank: 2

贡献
2122
鲜花
40
注册时间
2007-10-12

QQ绑定落伍微信绑定落伍手机绑定

发表于 2021-4-20 15:48:01 | 显示全部楼层 来自 中国辽宁大连
对于mysql数据库,我只是用来存储,不进行占用资源的计算
如果确实需要搜索,使用第三方方案,使用Lucene.net来解决
回复 支持 反对

使用道具 举报

26

主题

808

帖子

1133

积分

落伍者(两全齐美)

Rank: 2

贡献
835
鲜花
1
注册时间
2005-12-24

落伍手机绑定

发表于 2021-4-20 15:49:28 | 显示全部楼层 来自 中国福建泉州
算出当天的时间戳范围
然后再搜这个范围的数据

评分

参与人数 1鲜花 +1 收起 理由
卧草泥马 + 1 落伍有你更精彩!

查看全部评分

回复 支持 反对

使用道具 举报

849

主题

1万

帖子

5895

积分

落伍者(三羊开泰)

Rank: 3Rank: 3

贡献
720
鲜花
17
注册时间
2010-11-25

落伍手机绑定

发表于 2021-4-20 15:57:58 | 显示全部楼层 来自 中国广东深圳
0度寂寞 发表于 2021-4-20 15:49
算出当天的时间戳范围
然后再搜这个范围的数据

这个方法可以
Nothing
回复 支持 反对

使用道具 举报

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

论坛客服/商务合作/投诉举报:2171544 (QQ)
落伍者创建于2001/03/14,本站内容均为会员发表,并不代表落伍立场!
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论!
落伍官方微信:2030286 邮箱:(djfsys@gmail.com|tech@im286.com)
© 2001-2014

浙公网安备 33060302000191号

浙ICP备11034705号 BBS专项电子公告通信管[2010]226号

  落伍法律顾问: ITlaw-庄毅雄

手机版|找回帐号|不能发帖?|Archiver|落伍者

GMT+8, 2024-11-27 02:47 , Processed in 0.053567 second(s), 32 queries , Gzip On.

返回顶部