查詢數(shù)據(jù)php數(shù)據(jù)庫(kù) php數(shù)據(jù)庫(kù)查詢結(jié)果處理

thinkphp008. 數(shù)據(jù)庫(kù)的數(shù)據(jù)查詢

008. 數(shù)據(jù)庫(kù)的數(shù)據(jù)查詢

成都創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比宣漢網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式宣漢網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋宣漢地區(qū)。費(fèi)用合理售后完善,十載實(shí)體公司更值得信賴。

本節(jié)課我們來(lái)了解一下數(shù)據(jù)庫(kù)的數(shù)據(jù)查詢方式,單數(shù)據(jù)、數(shù)據(jù)集和其它查詢。

一.單數(shù)據(jù)查詢

1. Db::table()中table必須指定完整數(shù)據(jù)表(包括前綴);

2. 如果希望只查詢一條數(shù)據(jù),可以使用find()方法,需指定where條件;

Db::table('tp_user')-where('id', 27)-find()

3. Db::getLastSql()方法,可以得到最近一條SQL查詢的原生語(yǔ)句;

SELECT * FROM `tp_user` LIMIT 1

4. 沒(méi)有查詢到任何值,則返回null;

5. 使用findOrFail()方法同樣可以查詢一條數(shù)據(jù),在沒(méi)有數(shù)據(jù)時(shí)拋出一個(gè)異常;

Db::table('tp_user')-where('id', 1)-findOrFail()

6. 使用findOrEmpty()方法也可以查詢一條數(shù)據(jù),但在沒(méi)有數(shù)據(jù)時(shí)返回一個(gè)空數(shù)組;

7. Db::table('tp_user')-where('id', 1)-findOrEmpty();

二.數(shù)據(jù)集查詢

1. 想要獲取多列數(shù)據(jù),可以使用select()方法;

Db::table('tp_user')-select(); SELECT * FROM `tp_user`

2. 多列數(shù)據(jù)在查詢不到任何數(shù)據(jù)時(shí)返回空數(shù)組,使用selectOrFail()拋出異常; Db::table('tp_user')-where('id', 1)-selectOrFail();

3. 在select()方法后再使用toArray()方法,可以將數(shù)據(jù)集對(duì)象轉(zhuǎn)化為數(shù)組;

4. 當(dāng)在數(shù)據(jù)庫(kù)配置文件中設(shè)置了前綴,那么我們可以使用name()方法忽略前綴; Db::name('user')-select();

三.其它查詢

1. 通過(guò)value()方法,可以查詢指定字段的值(單個(gè)),沒(méi)有數(shù)據(jù)返回null;

Db::name('user')-where('id', 27)-value('username');

$user = Db::table('tp_user')-select()-toArray(); dump($user);

2. 通過(guò)colunm()方法,可以查詢指定列的值(多個(gè)),沒(méi)有數(shù)據(jù)返回空數(shù)組; Db::name('user')-column('username');

3. 可以指定id作為列值的索引;

4. 如果處理的數(shù)據(jù)量巨大,成百上千那種,一次性讀取有可能會(huì)導(dǎo)致內(nèi)存開(kāi)銷過(guò)大;

5. 為了避免內(nèi)存處理太多數(shù)據(jù)出錯(cuò),可以使用chunk()方法分批處理數(shù)據(jù);

6. 比如,每次只處理100條,處理完畢后,再讀取100條繼續(xù)處理;

7. 可以利用游標(biāo)查詢功能,可以大幅度減少海量數(shù)據(jù)的內(nèi)存開(kāi)銷,它利用了PHP生成器特性。每次查詢只讀一行,然后再讀取時(shí),自動(dòng)定位到下一行繼續(xù)讀取;

Db::name('user')-column('username', 'id');

Db::table('tp_user')-chunk(3, function($users) { foreach ($users as $user) {

dump($user);

}

echo 1; });

$cursor = Db::table('tp_user')-cursor(); foreach($cursor as $user){

dump($user);

}

PHP數(shù)據(jù)庫(kù)查詢

?php

/**

*

@param

string

$url

地址url

*

@return

$array

返回url對(duì)應(yīng)的id

*/

function

getid($url){

//連接數(shù)據(jù)庫(kù)

mysql_connect('localhost','root','user')

or

die('數(shù)據(jù)庫(kù)鏈接失敗');

//不清楚數(shù)據(jù)庫(kù)名稱,這里用dbname代表數(shù)據(jù)庫(kù)名稱。需要替換為實(shí)際的數(shù)據(jù)庫(kù)名稱

mysql_select_db('dbname');

mysql_query('set

names

utf8');//如果頁(yè)面編碼是utf-8的。這里設(shè)置查詢的編碼為utf-8

$sql

=

"select

`id`

from

`visitor`

where

`file`='{$url}'";

$result

=

mysql_query($sql);

//不清楚url是不是會(huì)重復(fù),這里循環(huán)可以保證得到所有的id

while($row

=

mysql_fetch_assoc($result)){

$id[]

=

$row['id']

}

//如果url不會(huì)重復(fù)則使用$id[0],如果會(huì)重復(fù)則循環(huán)$id就可以得到每個(gè)id了。

return

$id;

}

php查詢數(shù)據(jù)庫(kù)

mysqli有兩種數(shù)據(jù)庫(kù)連接方式:

1、面向過(guò)程式連接:

mysqli_connect('localhost','xxx','xxx','xxx');

mysqli_query('');

后使用mysqli_fetch_assoc方法獲取到數(shù)據(jù)。

2、面向?qū)ο笫竭B接:

$mysqli?=?new?mysqli("localhost",?"my_user",?"my_password",?"world");

$result?=?$mysqli-query('');

后使用$result-fetch_assoc()獲取數(shù)據(jù)。

至于num_rows是獲取查詢到的行數(shù)的方法。

標(biāo)題名稱:查詢數(shù)據(jù)php數(shù)據(jù)庫(kù) php數(shù)據(jù)庫(kù)查詢結(jié)果處理
新聞來(lái)源:http://www.muchs.cn/article24/hphjce.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務(wù)器品牌網(wǎng)站制作、ChatGPT搜索引擎優(yōu)化、手機(jī)網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

微信小程序開(kāi)發(fā)