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的一个完整SMTP类(解决邮件服务器需要验证时的问题)
Oct 09 PHP
NT IIS下用ODBC连接数据库
Oct 09 PHP
php下通过IP获取地理位置的代码(小偷程序)
Jun 09 PHP
php数组函数序列之array_unique() - 去除数组中重复的元素值
Oct 29 PHP
PHP中的命名空间相关概念浅析
Jan 22 PHP
php替换字符串中间字符为省略号的方法
May 04 PHP
Yii2 hasOne(), hasMany() 实现三表关联的方法(两种)
Feb 15 PHP
使用Zttp简化Guzzle 调用
Jul 02 PHP
PHP PDOStatement::nextRowset讲解
Feb 01 PHP
Laravel创建数据库表结构的例子
Oct 09 PHP
浅谈PHP array_search 和 in_array 函数效率问题
Oct 15 PHP
PHP dirname功能及原理实例解析
Oct 28 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应用程序来获取Web服务器的状态信息
2006/10/09 PHP
Codeigniter出现错误提示Error with CACHE directory的解决方案
2014/06/12 PHP
PHP性能分析工具XHProf安装使用教程
2015/05/13 PHP
Thinkphp和Bootstrap结合打造个性的分页样式(推荐)
2016/08/01 PHP
Laravel+jQuery实现AJAX分页效果
2016/09/14 PHP
国外Lightbox v2.03.3 最新版 下载
2007/10/17 Javascript
JS与C#编码解码
2013/12/03 Javascript
基于jquery实现的图片在各种分辨率下未知的容器内上下左右居中
2014/05/11 Javascript
javascript实现rgb颜色转换成16进制格式
2015/07/10 Javascript
javascript实现全角半角检测的方法
2015/07/23 Javascript
浅谈JavaScript函数的四种存在形态
2016/06/08 Javascript
一个超简单的jQuery回调函数例子(分享)
2016/08/08 Javascript
详解nodejs中exports和module.exports的区别
2017/02/17 NodeJs
JS仿淘宝搜索框用户输入事件的实现
2017/06/19 Javascript
js实现把时间戳转换为yyyy-MM-dd hh:mm 格式(es6语法)
2017/12/28 Javascript
基于vue 添加axios组件,解决post传参数为null的问题
2018/03/05 Javascript
Angular父组件调用子组件的方法
2018/04/02 Javascript
使用vue-router为每个路由配置各自的title
2018/07/30 Javascript
vue使用混入定义全局变量、函数、筛选器的实例代码
2019/07/29 Javascript
对layui中的onevent 和event的使用详解
2019/09/06 Javascript
如何通过shell脚本自动生成vue文件详解
2019/09/10 Javascript
vue.js中ref及$refs的使用方法解析
2019/10/08 Javascript
Python生成随机数组的方法小结
2017/04/15 Python
简单了解OpenCV是个什么东西
2017/11/10 Python
使用python获取csv文本的某行或某列数据的实例
2018/04/03 Python
python爬虫使用requests发送post请求示例详解
2020/08/05 Python
python链表类中获取元素实例方法
2021/02/23 Python
HTML5边玩边学(1)画布实现方法
2010/09/21 HTML / CSS
localStorage、sessionStorage使用总结
2017/11/17 HTML / CSS
Python里面如何拷贝一个对象
2014/02/17 面试题
大学生找工作推荐信范文
2013/11/28 职场文书
高中数学教学反思
2014/01/30 职场文书
商务英语专业大学生职业生涯规划书
2014/09/14 职场文书
教师查摆问题及整改措施
2014/10/11 职场文书
个人廉洁自律总结
2015/03/06 职场文书
导游词之云南丽江古城
2019/09/17 职场文书