中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP怎么以指定字段為索引返回數據庫所取的數據數組

發布時間:2021-07-23 16:06:48 來源:億速云 閱讀:240 作者:chen 欄目:開發技術

本篇內容介紹了“PHP怎么以指定字段為索引返回數據庫所取的數據數組”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

很多情況下,我們從接觸一個新的項目到開發完成,再回過頭來仔細瀏覽一下自己寫的代碼,很多都是我們以前用熟練的代碼。所以,在完成每個新項目的時 候,適當的做些項目總結、代碼總結,或許你會在以后的項目中用得著,極有可能獲得意外的收獲,比如:代碼優化,想到了更好、速度更快的實現方法等等。

牛逼的程序開發者有時候不在于代碼量的多少,而是程序的代碼簡潔性、邏輯復雜但實現的方便性,這些才說明是否是一位好的程序員。我們不做日夜加班到深夜,拼代碼量的程序員!
這篇和大家分享幾個使用得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怎么以指定字段為索引返回數據庫所取的數據數組”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

php
AI

丰台区| 兰坪| 龙海市| 武隆县| 乐昌市| 营口市| 芜湖市| 麦盖提县| 万年县| 大名县| 英山县| 龙州县| 永宁县| 红河县| 罗平县| 湖口县| 平陆县| 剑河县| 碌曲县| 巧家县| 永州市| 泾源县| 班戈县| 疏附县| 宝坻区| 吐鲁番市| 封丘县| 福建省| 和硕县| 天祝| 科技| 电白县| 宣恩县| 三穗县| 南溪县| 南宫市| 芦山县| 闽侯县| 休宁县| 万安县| 加查县|