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

Posted

篇首语:惜时专心苦读是做学问的一个好方法。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 PHP以指定字段为索引返回数据库所取的数据数组相关的知识,希望对你有一定的参考价值。

PHP以指定字段为索引返回数据库所取的数据数组  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

  很多情况下 我们从接触一个新的项目到开发完成 再回过头来仔细浏览一下自己写的代码 很多都是我们以前用熟练的代码 所以 在完成每个新项目的时 候 适当的做些项目总结 代码总结 或许你会在以后的项目中用得着 极有可能获得意外的收获 比如 代码优化 想到了更好 速度更快的实现方法等等 牛逼的程序开发者有时候不在于代码量的多少 而是程序的代码简洁性 逻辑复杂但实现的方便性 这些才说明是否是一位好的程序员 我们不做日夜加班到深夜 拼代码量的程序员! 这篇和大家分享几个使用得PHP编程技巧 有些技巧是在看别人代码的时候学来的 有些是自己总结的 以特定字段为索引 返回数据库取的数据数组 举个例子容易些 假如你要统计指定站点从其它网站来的流量情况 并且做一个小后台 查看每个网站每天带来的流量情况 我们先建 张数据表 表一 站点配置表(只统计这些网站的流量)

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

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

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

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

复制代码 代码如下: SELECT sid site_url site_name FROM site_config

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

复制代码 代码如下: SELECT sid COUNT( ) AS e_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($sql sid ); //站点流量数据 以sid为索引返回二维数组 cha138/Article/program/PHP/201311/21016

相关参考

知识大全 基于php常用函数总结(数组,字符串,时间,文件操作)

  数组:【重点】implode(分隔arr)把数组值数据按指定字符连接起来例如$arr=array();$str=implode($arr);explode([分隔]arr)按指定规则对一个字符串进

知识大全 PHP+AJAX无刷新实现返回天气预报数据

PHP+AJAX无刷新实现返回天气预报数据  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!天气数据是

知识大全 php执行数据库查询返回json格式数据

  <?php  //需要执行的SQL语句//单条$sql="selectidnamefromtbl_userwhereid=";//多条数据//$sql="selectidnamefromtb

知识大全 如何利用php数组对百万数据进行排重

  如何利用php数组对百万数据进行排重  在平时的工作中经常接到要对网站的会员进行站内信手机短信email进行群发信息的通知用户列表一般由别的同事提供当中难免会有重复为了避免重复发送所以我在进行发送

知识大全 php获取数组中重复数据的两种方法

  ()利用php提供的函数array_unique和array_diff_assoc来实现复制代码代码如下:<?phpfunctionFetchRepeatMemberInArray($arr

知识大全 php中遍历数组方法

  遍历数组有多种实现方法  连续索引的数组  实现连续数组的遍历很简单因为数组的索引是连续的(……)所以我们可以首先用count()函数计算出数组中元素的个数然后建立一个for循环如下  $subj

知识大全 asp 数组动态定义数组与静态数据定义方法

  这是假设你知道数组的基本特征所以让我们考虑如何处理在VBScript中的ASP  在VBScript中的数组是这意味着数组元素的索引总是从开始指数代表的数组  中的第一个位置指数代表数组中的第二位

知识大全 php数组相关函数的使用

  创建数组就不再说了array()函数  提取数组可以用list()  测试数组元素可以用is_array()  接受一个参数传进来的变量如果变量是数组返回true如果不是返回false  添加和删

知识大全 php关联数组排序(快速排序)

  使用环境和条件  有这样一种情况php里面的关联数组如果下面这样的数组数据  [php]  $array=array(  array(  name=>xiao  age=>  )  a

知识大全 oracle数据库中sql基础

  一关系数据库的一些概念    主键的值一般不可以改变    外键指向另一个表或本表的主键或唯一键的字段外键的值一定要和某一主键相同或者为空    数据库对像表视图序列索引同义词程序(进程函数sql