php

位置:IT落伍者 >> php >> 浏览文章

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


发布日期:2023年06月21日
 
PHP以指定字段为索引返回数据库所取的数据数组

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

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

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

复制代码 代码如下:
CREATE TABLE `site_config` (
`id` smallint() unsigned NOT NULL auto_increment COMMENT 主键自增
`sid` smallint() unsigned NOT NULL COMMENT 网站ID
`site_url` varchar() NOT NULL COMMENT 网站URL地址
`site_name` varchar() NOT NULL COMMENT 网站名称
`add_time` timestamp NOT NULL default CURRENT_TIMESTAMP COMMENT 添加时间
PRIMARY KEY (`id`)
UNIQUE KEY `adid` (`sid`)
) ENGINE=MyISAM DEFAULT CHARSET=utf COMMENT=站点配置表;


表二站点流量统计表(来一个用户一条记录)

复制代码 代码如下:
CREATE TABLE `site_stat` (
`id` int() unsigned NOT NULL auto_increment COMMENT 主键自增
`sid` smallint() unsigned NOT NULL COMMENT 网站ID
`ip_address` varchar() NOT NULL COMMENT 用户IP
`add_time` timestamp NOT NULL default CURRENT_TIMESTAMP COMMENT 添加时间
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf COMMENT=站点流量统计表 ;


因为site_config表读操作大于写操作所以类型设置为MyISAM而site_stat表写操作大于读操作因此我把表类型设置为InnoDB(这些地方也是你在设计数据的时候需要考虑的速度提高不少)
回到正题假如表site_config里有这样几条数据
数据格式为idsidsite_urladd_time
baiducom ::
googlecom ::
cnblogscom ::
codejianet ::
站点流量统计表site_stat里已经产生了一些数据如下
数据格式为idsidip_addressadd_time
::
::
::
::
::
::
::
你在后台需要做的报表格式为日期网站ID网站URL流量数 (没有流量的站点也要展示流量显示为
你可能会想到根据日期在表site_stat里根据sid group by之后再left join表site_config这显然不是我将分享的方法
条SQL来搞定一条是取所有的站点另一条是取指定日期下站点流量统计数

SQL取所有站点

复制代码 代码如下:
SELECT sidsite_urlsite_name FROM site_config


SQL取站点统计(假如为今天):

复制代码 代码如下:
SELECT sidCOUNT() AS come_total FROM site_stat
WHERE add_time>= ::
AND add_time<= ::
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($sql); //所有站点
$data = getList($sqlsid); //站点流量数据以sid为索引返回二维数组


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

最后看下上表的统计结果报表
格式为日期网站ID网站URL流量数
baiducom
googlecom
cnblogscom
codejianet
总结貌似写这么多就说明那样一个小的技巧哈但是可千万别小看这个技巧能节约你很多时间所以大家在写代码的时候多多总结多多来博客园和大家交流学习编程水平一定会进步很快的!

               

上一篇:PHP执行linux系统命令

下一篇:php 将 HTML 转换成文本