php查詢及多條件查詢
單條件查詢:
1.先要有一張表,顯示出表中的數(shù)據(jù):
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>無標(biāo)題文檔</title>
</head>
<body>
<table border="1" cellspacing="0" cellpadding="0">
<tr>
<td width="200">編號(hào)</td>
<td width="200">姓名</td>
<td width="200">電話</td>
<td width="200" >分組</td>
</tr>
<?php
$db = new mysqli("localhost","root","12345678","heiheihei");
$sql = "select * from contacts";
$r = $db->query($sql);
//傳值
while ($attr = $r->fetch_row())
{
echo " <tr>
<td>{$attr[0]}</td>
<td>{$attr[1]}</td>
<td>{$attr[2]}</td>
<td>{$attr[3]}</td>
</tr>";
}
?>
</table>
</body>
</html>
上圖:

啥都沒改的一張表
2.再來個(gè)from表單,讓用戶輸入,點(diǎn)擊查詢:
<form action="shouye.php" method="post">
<div>
輸入名字:<input type="text" name="name"/>
<input type="submit" value="查詢"/>
</div>
</form>
如圖:

3.建立關(guān)鍵字查詢:
<?php
//實(shí)現(xiàn)兩個(gè)邏輯
//1.如果沒有post數(shù)據(jù).查所有的
//2.如果有post數(shù)據(jù).根據(jù)條件查
$db = new mysqli("localhost","root","12345678","heiheihei");
//連接數(shù)據(jù)庫(kù)
$tj = " 1 = 1 ";
$name="";
//恒成立,如果沒有寫數(shù)據(jù),那就讓條件等于1=1,這個(gè)條件是查找所有的數(shù)據(jù)
//如果你寫入數(shù)據(jù),按照數(shù)據(jù)查
if(!empty($_POST))
{
$name = $_POST['name'];
$tj = " name like '%{$name}%'";
}
//將條件拼接到SQl語句
$sql = "select * from contacts WHERE {$tj}";
echo $sql;
//查出來
$r = $db->query($sql);
//傳值
if($r)
//開始判斷
{
//$attr已經(jīng)接收到了值,現(xiàn)在只需要獲取他的索引就行了
while ($attr = $r->fetch_row())
{
//關(guān)鍵字特殊查詢
$str = str_replace($name,"<mark>{$name}</mark>",$attr[1]); //查找替換如ctrl+f
//substr_replace(); 在指定位置替換
//substr(); 截取字符串
$gname = "select gname from groups WHERE gid='{$attr[3]}'";
//分組表中的gid,和我點(diǎn)擊的
$nresult = $db->query($gname);
$gname = $nresult->fetch_row();
$nation = $gname[0];
echo " <tr>
<td>{$attr[0]}</td>
<td>{$str}</td>
<td>{$attr[2]}</td>
<td>{$nation}</td>
?>
圖:

多條件查詢:
前面照舊;
出了php的語句:
<?php
//實(shí)現(xiàn)兩個(gè)邏輯
//1.如果沒有post數(shù)據(jù).查所有的
//2.如果有post數(shù)據(jù).根據(jù)條件查
$db = new mysqli("localhost","root","12345678","heiheihei");
//連接數(shù)據(jù)庫(kù)
$tj1 = " 1 = 1 ";
$tj2 = " 1 = 1 ";//兩個(gè)條件的恒等
$name="";
//恒成立,如果沒有寫數(shù)據(jù),那就讓條件等于1=1,這個(gè)條件是查找所有的數(shù)據(jù)
//如果你寫入數(shù)據(jù),按照數(shù)據(jù)查
if(!empty($_POST["name"])) //第一個(gè)條件的判斷(用到了模糊查詢)
{
$name = $_POST['name'];
$tj1 = " name like '%{$name}%'";
}
if(!empty($_POST["tel"]))
{
$tel = $_POST["tel"];
$tj2 = "tel = '$tel'";
}
//將條件拼接到SQl語句
$sql = "select * from contacts WHERE {$tj1} AND {$tj2}";
效果圖:

這樣:有幾個(gè)條件就做幾個(gè)條件變量,第一個(gè)條件不為空就執(zhí)行的第一個(gè)條件,第二個(gè)條件不為空?qǐng)?zhí)行的第二個(gè)條件,兩個(gè)都為空就是查尋所有的數(shù)據(jù)
相關(guān)文章
深入Memcache的Session數(shù)據(jù)的多服務(wù)器共享詳解
本篇文章是對(duì)Memcache的Session數(shù)據(jù)的多服務(wù)器共享進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
mysql 查詢指定日期時(shí)間內(nèi)sql語句實(shí)現(xiàn)原理與代碼
查詢指定日期時(shí)間內(nèi)sql語句實(shí)現(xiàn)原理:如果是月份就是當(dāng)前的月減去你要統(tǒng)計(jì)的時(shí)間如我要查詢數(shù)據(jù)庫(kù)中從今天起往前三個(gè)月的所有記錄2012-12-12
PHP中上傳多個(gè)文件的表單設(shè)計(jì)例子
這篇文章主要介紹了PHP中上傳多個(gè)文件的表單設(shè)計(jì)例子,本文著重講解的是表單如何設(shè)計(jì),后端處理需要循環(huán)$_FILES數(shù)組來實(shí)現(xiàn),需要的朋友可以參考下2014-11-11
PHP中根據(jù)IP地址判斷城市實(shí)現(xiàn)城市切換或跳轉(zhuǎn)代碼
先要獲取ip地址相當(dāng)簡(jiǎn)單,下面先介紹兩種獲取IP地址的代碼,后面需要利用QQIP庫(kù)來查找當(dāng)前IP是屬于那個(gè)IP段然后得出城市字段并返回2012-09-09
刪除html標(biāo)簽得到純文本可處理嵌套的標(biāo)簽
這篇文章主要介紹了通過刪除html標(biāo)簽得到的純文本可處理嵌套的標(biāo)簽,需要的朋友可以參考下2014-04-04
理解PHP中的Session及對(duì)Session有效期的控制
這篇文章主要介紹了理解PHP中的Session及對(duì)Session有效期的控制,Session默認(rèn)有效期為1440秒而后則會(huì)用到PHP的垃圾回收,需要的朋友可以參考下2016-01-01

