php怎么查詢數(shù)據(jù)庫數(shù)據(jù) php連接數(shù)據(jù)庫查詢數(shù)據(jù)

thinkphp 數(shù)據(jù)庫查詢怎么查?

thinkphp如何查詢數(shù)據(jù)庫?

成都創(chuàng)新互聯(lián)服務項目包括蓋州網(wǎng)站建設、蓋州網(wǎng)站制作、蓋州網(wǎng)頁制作以及蓋州網(wǎng)絡營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關系等,向廣大中小型企業(yè)、政府機構等提供互聯(lián)網(wǎng)行業(yè)的解決方案,蓋州網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務的客戶以成都為中心已經(jīng)輻射到蓋州省份的部分城市,未來相信會繼續(xù)擴大服務區(qū)域并繼續(xù)獲得客戶的支持與信任!

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

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

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

ThinkPHP可以支持直接使用字符串作為查詢條件,但是大多數(shù)情況推薦使用索引數(shù)組或者對象來作為查詢條件,因為會更加安全。

查詢方式

一、使用字符串作為查詢條件

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

1

2

$User = M("User"); // 實例化User對象

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

最后生成的SQL語句是

1

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

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

1

2

3

4

5

$User = M("User"); // 實例化User對象

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

$condition['status'] = 1;

// 把查詢條件傳入查詢方法

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

最后生成的SQL語句是

1

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

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

1

2

3

4

5

6

$User = M("User"); // 實例化User對象

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

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

$condition['_logic'] = 'OR'; //定義查詢邏輯

// 把查詢條件傳入查詢方法

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

最后生成的SQL語句是

1

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

三、使用對象方式來查詢 (這里以stdClass內置對象為例)

1

2

3

4

5

6

$User = M("User"); // 實例化User對象

// 定義查詢條件

$condition = new stdClass();

$condition-name = 'thinkphp';

$condition-status= 1;

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

最后生成的SQL語句和上面一樣

1

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

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

表達式查詢

上面的查詢條件僅僅是一個簡單的相等判斷,可以使用查詢表達式支持更多的SQL查詢語法,并且可以用于數(shù)組或者對象方式的查詢(下面僅以數(shù)組方式為例說明),查詢表達式的使用格式:

1

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

表達式不分大小寫,支持的查詢表達式有下面幾種,分別表示的含義是:

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%' 模糊查詢

$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')

本文來自ThinkPHP框架技術文章欄目:

以上就是thinkphp如何查詢數(shù)據(jù)庫的詳細內容,更多請關注php中文網(wǎng)其它相關文章!

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

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

本節(jié)課我們來了解一下數(shù)據(jù)庫的數(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查詢的原生語句;

SELECT * FROM `tp_user` LIMIT 1

4. 沒有查詢到任何值,則返回null;

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

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

6. 使用findOrEmpty()方法也可以查詢一條數(shù)據(jù),但在沒有數(shù)據(jù)時返回一個空數(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ù)組,使用selectOrFail()拋出異常; Db::table('tp_user')-where('id', 1)-selectOrFail();

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

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

三.其它查詢

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

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

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

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

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

4. 如果處理的數(shù)據(jù)量巨大,成百上千那種,一次性讀取有可能會導致內存開銷過大;

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

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

7. 可以利用游標查詢功能,可以大幅度減少海量數(shù)據(jù)的內存開銷,它利用了PHP生成器特性。每次查詢只讀一行,然后再讀取時,自動定位到下一行繼續(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 session登陸成功后怎么查詢數(shù)據(jù)庫

在使用php session進行數(shù)據(jù)查詢時主要有3中方法。第一種是使用函數(shù)【mysql_connect()】建立和MYSQL數(shù)據(jù)庫的連接。mysql_connect()是用來建立和MYSQL數(shù)據(jù)庫的連接,一共有5個參數(shù),一般情況下只使用前3個參數(shù),分別是MySQL服務器地址、用戶名以及密碼。第二種是使用函數(shù)【mysql_select_db()】指定要操作的數(shù)據(jù)庫。mysql_select_db()是用來指定要操作的數(shù)據(jù)庫。要是需要操作的數(shù)據(jù)庫還沒有創(chuàng)建,則需要創(chuàng)建數(shù)據(jù)庫,然后再創(chuàng)建數(shù)據(jù)庫中的表。第三種是使用函數(shù)【mysql_query()】查詢指令。mysql_query()是查詢指令的專用函數(shù),所有的SQL語句都通過它執(zhí)行,并返回結果集。一般情況下這三種方法是最適用的,希望可以解決你的問題。

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

創(chuàng)建數(shù)據(jù)庫

選擇開始菜單中→程序→【Management SQL Server 2008】→【SQL Server Management Studio】命令,打開【SQL Server Management Studio】窗口,并使用Windows或 SQL Server身份驗證建立連接。

在【對象資源管理器】窗口中展開服務器,然后選擇【數(shù)據(jù)庫】節(jié)點

右鍵單擊【數(shù)據(jù)庫】節(jié)點,從彈出來的快捷菜單中選擇【新建數(shù)據(jù)庫】命令。

執(zhí)行上述操作后,會彈出【新建數(shù)據(jù)庫】對話框。在對話框、左側有3個選項,分別是【常規(guī)】、【選項】和【文件組】。完成這三個選項中的設置會后,就完成了數(shù)據(jù)庫的創(chuàng)建工作,

在【數(shù)據(jù)庫名稱】文本框中輸入要新建數(shù)據(jù)庫的名稱。例如,這里以“新建的數(shù)據(jù)庫”。

在【所有者】文本框中輸入新建數(shù)據(jù)庫的所有者,如sa。根據(jù)數(shù)據(jù)庫的使用情況,選擇啟用或者禁用【使用全文索引】復選框。

在【數(shù)據(jù)庫文件】列表中包括兩行,一行是數(shù)據(jù)庫文件,而另一行是日記文件。通過單擊下面的【添加】、【刪除】按鈕添加或刪除數(shù)據(jù)庫文件。

切換到【選項頁】、在這里可以設置數(shù)據(jù)庫的排序規(guī)則、恢復模式、兼容級別和其他屬性。

切換到【文件組】頁,在這里可以添加或刪除文件組。

完成以上操作后,單擊【確定】按鈕關閉【新建數(shù)據(jù)庫】對話框。至此“新建的數(shù)據(jù)”數(shù)據(jù)庫創(chuàng)建成功。新建的數(shù)據(jù)庫可以再【對象資源管理器】窗口看到。

怎樣試用PHP原生語句查詢數(shù)據(jù)庫

原生SQL查詢有 query() 和 execute() 兩個方法:

query():用于 SQL 查詢操作,并返回符合查詢條件的數(shù)據(jù)集

execute():更新和寫入數(shù)據(jù)的 SQL 操作,返回影響的記錄數(shù)

query()

query() 方法是用于 SQL 查詢操作,和select()方法一樣返回符合查詢條件的數(shù)據(jù)集。

例子:

public function read(){

// 實例化一個空模型,沒有對應任何數(shù)據(jù)表

$Dao = M();

//或者使用 $Dao = new Model();

$list = $Dao-query("select * from user where uid5");

if($list){

$this-assign('list', $list );

$this-display();

} else {

$this-error($Dao-getError());

}

}

對于 query() 方法返回的數(shù)據(jù)集,跟 select() 一樣,可以在模板里直接循環(huán)輸出。

execute()

execute() 方法用于更新和寫入數(shù)據(jù)的 SQL 操作(注:非查詢操作,無返回數(shù)據(jù)集),返回影響的記錄數(shù)。

例子:

public function read(){

header("Content-Type:text/html; charset=utf-8");

// 實例化一個空模型,沒有對應任何數(shù)據(jù)表

$Dao = M();

//或者使用 $Dao = new Model();

$num = $Dao-execute("update user set email = '12345@xxx.com' where uid=3");

if($num){

echo '更新 ',$num,' 條記錄。';

}else{

echo '無記錄更新';

}

}

如果查詢比較復雜或一些特殊的數(shù)據(jù)操作不能通過 ThinkPHP 內置的 ORM 和 ActiveRecord 模式實現(xiàn)時,就可以通過直接使用原生 SQL 查詢來實現(xiàn)。

注意:以上都是 user 沒有表前綴的例子,在查詢語句中,查詢的表應該寫實際的表名字(包括前綴)。

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

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

1、面向過程式連接:

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

mysqli_query('');

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

2、面向對象式連接:

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

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

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

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

當前名稱:php怎么查詢數(shù)據(jù)庫數(shù)據(jù) php連接數(shù)據(jù)庫查詢數(shù)據(jù)
轉載注明:http://muchs.cn/article6/hjdjog.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、營銷型網(wǎng)站建設企業(yè)建站、品牌網(wǎng)站設計虛擬主機、Google

廣告

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

小程序開發(fā)