php數(shù)據(jù)庫(kù)查詢(xún)工具 php數(shù)據(jù)庫(kù)查詢(xún)結(jié)果處理

求高人給一個(gè)用PHP+MySQL實(shí)現(xiàn)的簡(jiǎn)單的數(shù)據(jù)庫(kù)查詢(xún)功能的PHP和HTML代碼

首先我是新手, 看到這個(gè)問(wèn)題試了下, 不知道能不能幫助你!希望~

成都創(chuàng)新互聯(lián)成立于2013年,是專(zhuān)業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目成都網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站、外貿(mào)網(wǎng)站建設(shè)網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元思明做網(wǎng)站,已為上家服務(wù),為思明各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:18982081108

還有很多條件沒(méi)有判斷, 我正則不是很會(huì)。 寫(xiě)的很粗糙,勉強(qiáng)能用, 希望別介意哈!

?php

class Database {

public $conn;

public function Database() {

$this-conn = mysql_connect("localhost","user","password");

mysql_select_db("gamesearch",$this-conn);

mysql_query("SET NAMES 'UTF8'");

}

public function get_data_array($sql) {

$rs = mysql_query($sql,$this-conn);

$data_array = array();

while($data = mysql_fetch_array($rs,MYSQL_ASSOC)) {

$data_array[] = $data;

}

mysql_free_result($rs);

return $data_array;

}

}

$db = new Database();

if($_GET['year'] == "") {

echo "請(qǐng)輸入年份!";

}else {

if($_GET['year'] == "all") {

$sql = "select GameName from GameSearch";

}else {

$sql = "select GameName from GameSearch where ReleaseYear = ".$_GET['year'];

}

$data = $db-get_data_array($sql);

foreach($data as $k=$v) {

echo $v['GameName']."br /";

}

}

?

form action="test.php" method="get"

年份:input type="text" name="year" value="all" /

input type="submit" value="提交" /

/form

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

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

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

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

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

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

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

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

SELECT * FROM `tp_user` LIMIT 1

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

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

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

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

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

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

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

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

2. 多列數(shù)據(jù)在查詢(xún)不到任何數(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();

三.其它查詢(xún)

1. 通過(guò)value()方法,可以查詢(xún)指定字段的值(單個(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()方法,可以查詢(xún)指定列的值(多個(gè)),沒(méi)有數(shù)據(jù)返回空數(shù)組; Db::name('user')-column('username');

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

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

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

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

7. 可以利用游標(biāo)查詢(xún)功能,可以大幅度減少海量數(shù)據(jù)的內(nèi)存開(kāi)銷(xiāo),它利用了PHP生成器特性。每次查詢(xún)只讀一行,然后再讀取時(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);

}

thinkphp 數(shù)據(jù)庫(kù)查詢(xún)?cè)趺床椋?/h2>

thinkphp如何查詢(xún)數(shù)據(jù)庫(kù)?

數(shù)據(jù)庫(kù)查詢(xún)

ThinkPHP內(nèi)置了非常靈活的查詢(xún)方法,可以快速的進(jìn)行數(shù)據(jù)查詢(xún)操作。

查詢(xún)條件可以用于CURD等任何操作,作為where方法的參數(shù)傳入即可。

ThinkPHP可以支持直接使用字符串作為查詢(xún)條件,但是大多數(shù)情況推薦使用索引數(shù)組或者對(duì)象來(lái)作為查詢(xún)條件,因?yàn)闀?huì)更加安全。

查詢(xún)方式

一、使用字符串作為查詢(xún)條件

這是最傳統(tǒng)的方式,但是安全性不高,例如:

1

2

$User = M("User"); // 實(shí)例化User對(duì)象

$User-where('type=1 AND status=1')-select();

最后生成的SQL語(yǔ)句是

1

SELECT * FROM think_user WHERE type=1 AND status=1

二、使用數(shù)組作為查詢(xún)條件

1

2

3

4

5

$User = M("User"); // 實(shí)例化User對(duì)象

$condition['name'] = 'thinkphp';

$condition['status'] = 1;

// 把查詢(xún)條件傳入查詢(xún)方法

$User-where($condition)-select();

最后生成的SQL語(yǔ)句是

1

SELECT * FROM think_user WHERE 'name'='thinkphp' AND status=1

如果進(jìn)行多字段查詢(xún),那么字段之間的默認(rèn)邏輯關(guān)系是 邏輯與 AND,但是用下面的規(guī)則可以更改默認(rèn)的邏輯判斷,通過(guò)使用 _logic 定義查詢(xún)邏輯:

1

2

3

4

5

6

$User = M("User"); // 實(shí)例化User對(duì)象

$condition['name'] = 'thinkphp';

$condition['account'] = 'thinkphp';

$condition['_logic'] = 'OR'; //定義查詢(xún)邏輯

// 把查詢(xún)條件傳入查詢(xún)方法

$User-where($condition)-select();

最后生成的SQL語(yǔ)句是

1

SELECT * FROM think_user WHERE 'name'='thinkphp' OR `account`='thinkphp'

三、使用對(duì)象方式來(lái)查詢(xún) (這里以stdClass內(nèi)置對(duì)象為例)

1

2

3

4

5

6

$User = M("User"); // 實(shí)例化User對(duì)象

// 定義查詢(xún)條件

$condition = new stdClass();

$condition-name = 'thinkphp';

$condition-status= 1;

$User-where($condition)-select();

最后生成的SQL語(yǔ)句和上面一樣

1

SELECT * FROM think_user WHERE `name`='thinkphp' AND status=1

使用對(duì)象方式查詢(xún)和使用數(shù)組查詢(xún)的效果是相同的,并且是可以互換的,大多數(shù)情況下,我們建議采用數(shù)組方式更加高效,后面我們會(huì)以數(shù)組方式為例來(lái)講解具體的查詢(xún)語(yǔ)言用法。

表達(dá)式查詢(xún)

上面的查詢(xún)條件僅僅是一個(gè)簡(jiǎn)單的相等判斷,可以使用查詢(xún)表達(dá)式支持更多的SQL查詢(xún)語(yǔ)法,并且可以用于數(shù)組或者對(duì)象方式的查詢(xún)(下面僅以數(shù)組方式為例說(shuō)明),查詢(xún)表達(dá)式的使用格式:

1

$map['字段名'] = array('表達(dá)式','查詢(xún)條件');

表達(dá)式不分大小寫(xiě),支持的查詢(xún)表達(dá)式有下面幾種,分別表示的含義是:

1

2

3

4

$map['id']? = array('eq',100);? id = 100;

$map['id']? = array('egt',100);id = 100

$map['name'] = array('like','thinkphp%'); name like 'thinkphp%' 模糊查詢(xún)

$map['a'] =array('like',array('%thinkphp%','%tp'),'OR');$map['b'] =array('notlike',array('%thinkphp%','%tp'),'AND'); (a like '%thinkphp%' OR a like '%tp') AND (b not like '%thinkphp%' AND b not like '%tp')

本文來(lái)自ThinkPHP框架技術(shù)文章欄目:

以上就是thinkphp如何查詢(xún)數(shù)據(jù)庫(kù)的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!

當(dāng)前名稱(chēng):php數(shù)據(jù)庫(kù)查詢(xún)工具 php數(shù)據(jù)庫(kù)查詢(xún)結(jié)果處理
本文來(lái)源:http://muchs.cn/article2/ddcejic.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)、網(wǎng)站內(nèi)鏈、企業(yè)建站、全網(wǎng)營(yíng)銷(xiāo)推廣、商城網(wǎng)站虛擬主機(jī)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(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)

綿陽(yáng)服務(wù)器托管