设为首页 收藏本站
查看: 650|回复: 0

[经验分享] Blue_birds

[复制链接]

尚未签到

发表于 2017-12-30 20:42:04 | 显示全部楼层 |阅读模式
  这几天在做数据统计,有几个统计图的需求是这样的: 按照年、月、日统计订单数量, 比方一年12个月,统计出1月多少订单,二月多少订单,按照这种模式统计。
  但是数据库里存放的是 timestamp  的 current_timestamp 默认值——"2016-12-16 12:30:00"。(这里许多公司会使用时间戳,其实都差不多)
  当时脑子里想到的第一种做法是,讲所有数据一次性取出来,然后foreach 一个个date()后,得到日期后再一个个去分组。
  后来考虑到如果数据量大了,性能上会不会出问题。就想到了mysql 内置的FROM_UNIXTIME() 函数 然后用一个group by 分组解决。
  date("Y-m-d", 1481862600) = 2016-12-16 12:30:00
  FROM_UNIXTIME(add_time, '%Y-%m-%d')
  为了比较两个函数之间的效率,我做了一个实验,
  1、创建一张表 只有三个字段
DSC0000.png

  

CREATE TABLE `t1` (  `id`
int(11) NOT NULL AUTO_INCREMENT,  `remark`
char(10) DEFAULT NULL,  `add_time`
int(11) DEFAULT NULL,PRIMARY KEY (`id`)  
) ENGINE
=InnoDB AUTO_INCREMENT=458731 DEFAULT CHARSET=latin1;  

  2、再用自我复制语句,迅速将表数据复制到了20多万条数据
  

INSERT INTO t1(remark,add_time) SELECT remark,add_time FROM t1  

  3、接下来是PHP的执行代码
  第一种,使用PHP的date函数循环赋值:
  

// 获取开始时间的微妙  
$startTime = (true);
  
$pdo = new PDO("mysql:host=localhost;dbname=test","root","");

  
$rs = $pdo -> query("select>  
$data = $rs->fetchAll();
  

  
$php_number_count = 0;
  
foreach ($data as $item){
  $php_number_count +=1;
  $tmp[] = ("Y-m-d", $item['add_time']);
  
}
  

  
echo $php_number_count."<br>";
  
echo "开始时间:".$startTime."<br>";
  
echo "结束时间:".$endTime = (true). "<br>";
  
$resTime = $endTime - $startTime;
  
echo "用时:".$resTime;exit;
  

  输出结果
  

262144  
开始时间:
1481871208.7704  
结束时间:
1481871210.1535  
用时:
1.3830921649933 秒  

  第二种使用mysql的FROM_UNIXTIME()函数
  

// 获取开始时间的微妙  
$startTime = (true);
  
$pdo = new PDO("mysql:host=localhost;dbname=test","root","");

  
$rs = $pdo -> query("select>  
$data = $rs->fetchAll();
  

  
echo "开始时间:".$startTime."<br>";
  
echo "结束时间:".$endTime = (true). "<br>";
  
$resTime = $endTime - $startTime;
  
echo "用时:".$resTime;exit;
  

  输出结果:
  

开始时间:1481871495.7308  
结束时间:
1481871496.7279  
用时:
0.99707913398743  

  从上面的结果显示明显是 使用 mysql的 FROM_UNIXTIME()函数要快一些
  但是发现在使用PHP的date()函数里 多个一个对结果集的foreach 循环,为了保证数据的严谨性,我又再 使用 mysql的 FROM_UNIXTIME() 的后面加了一个结果集的foreach循环来尽量保证结果的准确性 如下
  

// ..........  
$data = $rs->fetchAll();
  
foreach ($data as $row){
  $tmp[] = $row['add_time'];
  
};
  
// .........
  

  结果:
  

开始时间:1481871764.8102  
结束时间:
1481871766.0483  
用时:
1.2380890846252  

  为了尽量避免数据的偏差性、不稳定性,每份代码我分别执行了10次,并记录下结果
DSC0001.png

  最后得出的结果是, 使用FROM_UNIXTIME()函数 是速度是最快的,如果group by 后能直接得到想要的结果集,那自然是最好的。
  不过我们不能忽略mysql数据库执行的开销。毕竟执行中一定程度上会加大数据库的压力。
  最后这个世界是没有最好的办法,只有最适合的办法。 如果哪位大侠有哪种更好的办法,欢迎分享。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-430111-1-1.html 上篇帖子: pecl 轻松安装php扩展 下篇帖子: 用PHP实现URL转换短网址的算法示例
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

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