PHP以指定字段为索引返回数据库所取的数据数组


Posted in PHP onJune 30, 2013

很多情况下,我们从接触一个新的项目到开发完成,再回过头来仔细浏览一下自己写的代码,很多都是我们以前用熟练的代码。所以,在完成每个新项目的时 候,适当的做些项目总结、代码总结,或许你会在以后的项目中用得着,极有可能获得意外的收获,比如:代码优化,想到了更好、速度更快的实现方法等等。

牛逼的程序开发者有时候不在于代码量的多少,而是程序的代码简洁性、逻辑复杂但实现的方便性,这些才说明是否是一位好的程序员。我们不做日夜加班到深夜,拼代码量的程序员!
这篇和大家分享几个使用得PHP编程技巧,有些技巧是在看别人代码的时候学来的,有些是自己总结的。

以特定字段为索引,返回数据库取的数据数组
举个例子容易些:
假如你要统计指定站点从其它网站来的流量情况,并且做一个小后台,查看每个网站每天带来的流量情况。我们先建2张数据表:
表一、站点配置表(只统计这些网站的流量)

CREATE TABLE `site_config` ( 
`id` smallint(5) unsigned NOT NULL auto_increment COMMENT '主键,自增', 
`sid` smallint(5) unsigned NOT NULL COMMENT '网站ID', 
`site_url` varchar(128) NOT NULL COMMENT '网站URL地址', 
`site_name` varchar(80) NOT NULL COMMENT '网站名称', 
`add_time` timestamp NOT NULL default CURRENT_TIMESTAMP COMMENT '添加时间', 
PRIMARY KEY (`id`), 
UNIQUE KEY `adid` (`sid`) 
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='站点配置表';

表二、站点流量统计表(来一个用户一条记录)
CREATE TABLE `site_stat` ( 
`id` int(11) unsigned NOT NULL auto_increment COMMENT '主键,自增', 
`sid` smallint(5) unsigned NOT NULL COMMENT '网站ID', 
`ip_address` varchar(32) NOT NULL COMMENT '用户IP', 
`add_time` timestamp NOT NULL default CURRENT_TIMESTAMP COMMENT '添加时间', 
PRIMARY KEY (`id`) 
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='站点流量统计表' ;

因为site_config表读操作大于写操作,所以类型设置为MyISAM;而site_stat表写操作大于读操作,因此,我把表类型设置为InnoDB。(这些地方也是你在设计数据的时候需要考虑的,速度提高不少)。
回到正题,假如表site_config里有这样几条数据:
数据格式为:id,sid,site_url,add_time
1,200,baidu.com,2013-06-30 14:20:00
2,201,google.com,2013-06-30 14:20:00
3,202,cnblogs.com,2013-06-30 14:20:00
4,203,codejia.net,2013-06-30 14:20:00
站点流量统计表site_stat里已经产生了一些数据,如下:
数据格式为:id,sid,ip_address,add_time
1,200,167.87.32.4,2013-06-30 14:40:00
2,200,192.168.11.56,2013-06-30 14:40:10
3,202,167.87.32.4,2013-06-30 14:40:10
4,202,192.168.11.56,2013-06-30 14:40:20
5,203,167.87.32.4,2013-06-30 14:40:20
6,202,10.10.10.10,2013-06-30 14:40:30
7,200,167.87.32.4,2013-06-30 14:40:31
你在后台需要做的报表格式为:日期,网站ID,网站URL,流量数 (没有流量的站点也要展示,流量显示为0)
你可能会想到根据日期,在表site_stat里根据sid group by之后再left join表site_config,这显然不是我将分享的方法。
用2条SQL来搞定,一条是取所有的站点;另一条是取指定日期下站点流量统计数。

SQL1取所有站点:

SELECT sid,site_url,site_name FROM site_config

SQL2取站点统计(假如为今天):
SELECT sid,COUNT(1) AS come_total FROM site_stat 
WHERE add_time>='2013-06-30 00:00:00' 
AND add_time<='2013-06-30 23:59:59' 
GROUP BY sid

前面说了一大堆都是为后面做铺垫,分享一个PHP以传过去的字段为索引,返回二维数组的方法:
protected function getList($sql,$filed = null){ 
$res = mysql_query($sql,$this->link_sc); 
$data = array(); 
if($filed === null){ 
while($row = mysql_fetch_assoc($res)){ 
$data[] = $row; 
} 
}else{ 
while($row = mysql_fetch_assoc($res)){ 
$data[$row[$filed]] = $row; 
} 
} 
return $data; 
}

把你的SQL传进入,并把需要索引的字段传进入就OK,前提是传进去的字段必须要在select返回的字段里。
我们在取所有站点的时候不需要传过去字段,但在取站点流量统计的时候我们把,站点sid传过去,即如下:
$sites = getList($sql1); //所有站点 
$data = getList($sql2,'sid'); //站点流量数据,以sid为索引返回二维数组

最后在展示报表的时候,用foreach循环$sites,取流量的时候到数组$data里去取索引为sid的数据就OK了。
非常方便,并且非常容易掌握,我就经常这么干。

最后看下上表的统计结果报表:
格式为:日期,网站ID,网站URL,流量数
2013-06-30,200,baidu.com,3
2013-06-30,201,google.com,0
2013-06-30,202,cnblogs.com,3
2013-06-30,203,codejia.net,1
总结:貌似写这么多就说明那样一个小的技巧哈,但是,可千万别小看这个技巧,能节约你很多时间。所以,大家在写代码的时候多多总结,多多来博客园和大家交流、学习,编程水平一定会进步很快的!

PHP 相关文章推荐
提升PHP速度全攻略
Oct 09 PHP
利用static实现表格的颜色隔行显示
Oct 09 PHP
PHP时间戳 strtotime()使用方法和技巧
Oct 29 PHP
PHP exif扩展方法开启详解
Jul 28 PHP
javascript some()函数用法详解
Nov 13 PHP
用php守护另一个php进程的例子
Feb 13 PHP
Thinkphp模板标签if和eq的区别和比较实例分析
Jul 01 PHP
PHP版本的选择5.2.17 5.3.27 5.3.28 5.4 5.5兼容性问题分析
Apr 04 PHP
php分页查询的简单实现代码
Mar 14 PHP
php str_replace替换指定次数的方法详解
May 05 PHP
Laravel中的Blade模板引擎示例详解
Oct 10 PHP
Swoole4.4协程抢占式调度器详解
May 23 PHP
php设计模式之单例、多例设计模式的应用分析
Jun 30 #PHP
php获取$_POST同名参数数组的实现介绍
Jun 30 #PHP
深入解析php中的foreach问题
Jun 30 #PHP
浅析Apache中RewriteCond规则参数的详细介绍
Jun 30 #PHP
浅析关于PHP位运算的简单权限设计
Jun 30 #PHP
PHP删除HTMl标签的三种解决方法
Jun 30 #PHP
PHP删除HTMl标签的实现代码
Jun 30 #PHP
You might like
基于PHP CURL用法的深入分析
2013/06/09 PHP
PHP生成不重复随机数的方法汇总
2014/11/19 PHP
PHP间隔一段时间执行代码的方法
2014/12/02 PHP
WordPress中使主题支持小工具以及添加插件启用函数
2015/12/22 PHP
PHP程序中的文件锁、互斥锁、读写锁使用技巧解析
2016/03/21 PHP
PHP使用PHPExcel删除Excel单元格指定列的方法
2016/07/06 PHP
php实现不通过扩展名准确判断文件类型的方法【finfo_file方法与二进制流】
2017/04/18 PHP
onsubmit阻止form表单提交与onclick的相关操作
2010/09/03 Javascript
深入分析Javascript跨域问题
2015/04/17 Javascript
jquery实现简单的遮罩层
2016/01/08 Javascript
jQuery解决浏览器兼容性问题案例分析
2016/04/15 Javascript
轻松搞定js表单验证
2016/10/13 Javascript
JavaScript正则表达式替换字符串中图片地址(img src)的方法
2017/01/13 Javascript
关于vue中的ajax请求和axios包问题
2018/04/19 Javascript
详解Koa中更方便简单发送响应的方式
2018/07/20 Javascript
JavaScript数据结构与算法之二叉树添加/删除节点操作示例
2019/03/01 Javascript
微信小程序实现文件、图片上传功能
2020/08/18 Javascript
vue+element-ui+axios实现图片上传
2019/08/20 Javascript
vue项目强制清除页面缓存的例子
2019/11/06 Javascript
微信小程序开发打开另一个小程序的实现方法
2020/05/17 Javascript
Flexible.js可伸缩布局实现方法详解
2020/11/13 Javascript
[00:32]2018DOTA2亚洲邀请赛VG出场
2018/04/03 DOTA
python通过邮件服务器端口发送邮件的方法
2015/04/30 Python
详解Django框架中用户的登录和退出的实现
2015/07/23 Python
Python实现学生成绩管理系统
2020/04/05 Python
Python面向对象之反射/自省机制实例分析
2018/08/24 Python
Python timer定时器两种常用方法解析
2020/01/20 Python
python+django+selenium搭建简易自动化测试
2020/08/19 Python
改变 Python 中线程执行顺序的方法
2020/09/24 Python
html5菜单折纸效果
2014/04/22 HTML / CSS
HTML5轻松实现全屏视频背景的示例
2018/04/23 HTML / CSS
你的自行车健身专家:FaFit24
2016/11/16 全球购物
自行车租赁公司创业计划书
2014/01/28 职场文书
《油菜花开了》教学反思
2014/02/22 职场文书
2014年体育部工作总结
2014/11/13 职场文书
2016年学习雷锋精神广播稿
2015/12/17 职场文书