1、用navicat新建一個(gè)數(shù)據(jù)庫(kù)database1。
創(chuàng)新互聯(lián)公司專(zhuān)業(yè)為企業(yè)提供臨澤網(wǎng)站建設(shè)、臨澤做網(wǎng)站、臨澤網(wǎng)站設(shè)計(jì)、臨澤網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、臨澤企業(yè)網(wǎng)站模板建站服務(wù),十年臨澤做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。
2、在database1數(shù)據(jù)庫(kù)中新建一個(gè)表table2。
3、在table2中添加新的數(shù)據(jù),新建一個(gè)名稱(chēng)為mysql_query的數(shù)據(jù)庫(kù)。
4、在頁(yè)面中用mysql_connect 函數(shù)與數(shù)據(jù)庫(kù)建立連接。
5、用mysql_select_db函數(shù)選擇要查詢(xún)的數(shù)據(jù)庫(kù)。
6、添加一個(gè)查詢(xún) table2表的查詢(xún)語(yǔ)句“$sql=select * from table2“。
7、將查詢(xún)語(yǔ)句$sql添加到查詢(xún)數(shù)據(jù)庫(kù)函數(shù)mysql_query中,返回值賦值給變量query。
8、最后將mysql_query。php文件在瀏覽器中打開(kāi),查看查詢(xún)到數(shù)據(jù)庫(kù)中的內(nèi)容的結(jié)果。
在使用php session進(jìn)行數(shù)據(jù)查詢(xún)時(shí)主要有3中方法。第一種是使用函數(shù)【mysql_connect()】建立和MYSQL數(shù)據(jù)庫(kù)的連接。mysql_connect()是用來(lái)建立和MYSQL數(shù)據(jù)庫(kù)的連接,一共有5個(gè)參數(shù),一般情況下只使用前3個(gè)參數(shù),分別是MySQL服務(wù)器地址、用戶(hù)名以及密碼。第二種是使用函數(shù)【mysql_select_db()】指定要操作的數(shù)據(jù)庫(kù)。mysql_select_db()是用來(lái)指定要操作的數(shù)據(jù)庫(kù)。要是需要操作的數(shù)據(jù)庫(kù)還沒(méi)有創(chuàng)建,則需要?jiǎng)?chuàng)建數(shù)據(jù)庫(kù),然后再創(chuàng)建數(shù)據(jù)庫(kù)中的表。第三種是使用函數(shù)【mysql_query()】查詢(xún)指令。mysql_query()是查詢(xún)指令的專(zhuān)用函數(shù),所有的SQL語(yǔ)句都通過(guò)它執(zhí)行,并返回結(jié)果集。一般情況下這三種方法是最適用的,希望可以解決你的問(wè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);
}