可以使用閉包查詢,例
成都創(chuàng)新互聯(lián)公司,為您提供重慶網(wǎng)站建設(shè)公司、成都網(wǎng)站制作、網(wǎng)站營(yíng)銷推廣、網(wǎng)站開發(fā)設(shè)計(jì),對(duì)服務(wù)辦公空間設(shè)計(jì)等多個(gè)行業(yè)擁有豐富的網(wǎng)站建設(shè)及推廣經(jīng)驗(yàn)。成都創(chuàng)新互聯(lián)公司網(wǎng)站建設(shè)公司成立于2013年,提供專業(yè)網(wǎng)站制作報(bào)價(jià)服務(wù),我們深知市場(chǎng)的競(jìng)爭(zhēng)激烈,認(rèn)真對(duì)待每位客戶,為客戶提供賞心悅目的作品。 與客戶共同發(fā)展進(jìn)步,是我們永遠(yuǎn)的責(zé)任!
Db::table('think_user')-select(function($query){
$query-where('name','thinkphp')
-whereOr('id','',10);
});
where和whereOr都可以使用多個(gè)條件(數(shù)據(jù)格式)
在PHP中解析JSON主要用到j(luò)son_encode和json_decode兩個(gè)PHP
JSON函數(shù),比PHP解析XML方便很多,下面詳細(xì)介紹下PHP
JSON的使用。
JSON基礎(chǔ)介紹
JSON(JavaScript
Object
Notation)
是一種輕量級(jí)的數(shù)據(jù)交換格式。
JSON主要有兩種結(jié)構(gòu):
“名稱/值”對(duì)的集合,在PHP中可以理解為關(guān)聯(lián)數(shù)組
(associative
array)。
值的有序列表(An
ordered
list
of
values)。在PHP中可以理解為普通數(shù)組(array)。
對(duì)象是一個(gè)無(wú)序的“‘名稱/值'對(duì)”集合。一個(gè)對(duì)象以“{”(左括號(hào))開始,“}”(右括號(hào))結(jié)束。每個(gè)“名稱”后跟一個(gè)“:”(冒號(hào));“‘名稱/值'
對(duì)”之間使用“,”(逗號(hào))分隔。
數(shù)組是值(value)的有序集合。一個(gè)數(shù)組以“[”(左中括號(hào))開始,“]”(右中括號(hào))結(jié)束。值之間使用“,”(逗號(hào))分隔。值(value)可以是雙引號(hào)括起來(lái)的字符串(string)、數(shù)值(number)、true、false、
null、對(duì)象(object)或者數(shù)組(array)。這些結(jié)構(gòu)可以嵌套。
我目前對(duì)JSON的理解更偏向于數(shù)組,類似于PHP中的關(guān)聯(lián)數(shù)組,你可以將PHP數(shù)組轉(zhuǎn)換為JSON格式。
更多JSON的介紹請(qǐng)參考JSON官網(wǎng)和IBM關(guān)于JSON的介紹
PHP
JSON解析實(shí)例
PHP5.2開始已經(jīng)將JSON作為PHP擴(kuò)展的一部分,所以并不需要另外安裝JSON。另外為了保證下面的PHP
JSON實(shí)例不出現(xiàn)中文亂碼,請(qǐng)保證你的編碼格式為UTF8。
JSON是Javascript的一部分,首先我們看下Javascript中如何定義JSON
復(fù)制代碼
代碼如下:
var
json_obj
=
{'WebName':'PHP網(wǎng)站開發(fā)教程網(wǎng)'};
alert(json_obj.WebName);
var
json_arr
=[{'WebName':'PHP網(wǎng)站開發(fā)教程網(wǎng)','WebSite':''},{'ArtTitle':'PHP
JSON實(shí)例講解'}]
alert(json_arr[1].ArtTitle);
var
php_json
=
[['PHP網(wǎng)站開發(fā)教程網(wǎng)',''],['文章標(biāo)題','PHP
JSON實(shí)例講解']];
alert(php_json[1][0]);
在這段JSON實(shí)例代碼中我構(gòu)建了所有的JSON形式,
第1行,定義了JSON以對(duì)象形式存在
第4行,定義了JSON以數(shù)組形式存在,嵌套了JSON對(duì)象,所以有點(diǎn)類似于PHP的關(guān)聯(lián)數(shù)組,其實(shí)仍然是對(duì)象。
第7行,定了JSON以普通數(shù)組形式存在。
注意:由于Javascript是區(qū)分大小寫的,所以訪問JSON關(guān)聯(lián)數(shù)組對(duì)象時(shí)注意key的大小寫問題。
PHP與JSON格式數(shù)據(jù)交互時(shí),第一步需要將PHP數(shù)組轉(zhuǎn)換為JSON格式的數(shù)據(jù),可使用PHP5自帶的json_encode函數(shù),當(dāng)PHP解析傳遞過來(lái)的JSON格式數(shù)據(jù)時(shí)需要使用json_decode函數(shù)進(jìn)行解析轉(zhuǎn)換為PHP數(shù)組,PHP轉(zhuǎn)換并解析JSON數(shù)據(jù)的實(shí)例代碼如下
復(fù)制代碼
代碼如下:
?php
$json_arr
=
array('WebName'='PHP網(wǎng)站開發(fā)教程網(wǎng)','WebSite'='');
$php_json
=
json_encode($json_arr);
echo
$php_json;
$php_json
=
json_decode($php_json);
print_r($php_json);
?
說明:這里通過PHP定義了關(guān)聯(lián)數(shù)組,然后通過json_encode轉(zhuǎn)換為JSON格式的數(shù)據(jù),通過echo語(yǔ)句可以看到轉(zhuǎn)換后的JSON對(duì)象,通過PHP
JSON解析函數(shù)json_decode可以將JSON格式的數(shù)據(jù)解析為PHP的關(guān)聯(lián)數(shù)組。如果編碼不正確,JSON中文會(huì)出現(xiàn)亂碼。如果你使用Editplus調(diào)試PHP,請(qǐng)注意保存文件時(shí)編碼將ANSI改為UTF8。
最后我們來(lái)看下完整的PHP
JSON交互實(shí)例
復(fù)制代碼
代碼如下:
?php
$json_arr
=
array('WebName'='PHP網(wǎng)站開發(fā)教程網(wǎng)','WebSite'='');
$php_json
=
json_encode($json_arr);
?
script
type="text/javascript"
var
php_json
=
?=$php_json?;
/script
script
type="text/javascript"
function
php_json_dis(php_json)
{
alert(php_json.WebName);
alert(php_json.WebSite);
}
php_json_dis(php_json);
/script
至此,PHP通過json_encode和json_decode函數(shù)對(duì)JSON格式數(shù)據(jù)進(jìn)行轉(zhuǎn)換和解析的實(shí)例就介紹完了。
源代碼如下:
html
head
title打開CSV文件/title
/head
p
center
?php
$t_array=array(
array("1","張三","男","21","0921212"),
array("2","李四","女","20","0921212"),
array("3","王五","女","21","0921212"),
array("4","小六","男","22","0921212"),
array("5","田七","女","20","0921212")
);
$handle=fopen("html/stu.csv","w");
foreach ($stu as $line)
{fputcsv($handle,$line);}
fclose($handle);
echo"table border=1trtd學(xué)號(hào)/tdtd姓名/tdtd性別/tdtd年齡/tdtd班級(jí)/td/tr";
while (list($key,$value)=each($t_array))
{
list($XH,$XM,$XB,$NL,$BJ)=$value;
echo "trtd$XH/tdtd$XM/tdtd$XB/tdtd$NL/tdtd$BJ/td/tr";
}
echo"/table";
?
/p
/center
/body
/html
,剩下的就是你自己建立一個(gè)CSV文件,把對(duì)應(yīng)的內(nèi)容填寫完整就行了,記得把內(nèi)容換一下,不要照抄了啊