在数据库中,数据查询是通过Select语句完成的。Select语句可以从数据库中按用户要求提供的限定条件检索数据,并将查询结果以表格的形式返回。 例如,查询图书信息表中图书名称为PHP数据库系统开发完全手册的图书信息。代码如下: $sql=mysql_query("select *
在数据库中,数据查询是通过Select语句完成的。Select语句可以从数据库中按用户要求提供的限定条件检索数据,并将查询结果以表格的形式返回。
例如,查询图书信息表中图书名称为“PHP数据库系统开发完全手册”的图书信息。代码如下:
$sql=mysql_query("select * from tab_book where bookname='PHP数据库系统开发完全手册'");
$info=mysql_fetch_array($sql);
下面通过具体的范例来讲解数据查询的方法和技巧。
1)利用include包含文件命令引用数据库配置文件,即可访问数据库。代码如下:
(2)创建记录集。首先通过接收表单传递的值赋值给Session变量,然后利用If…Then…Else条件语句判断用户当前选择的操作符,从而执行相对应的SQL语句来检索商品的相关信息,并判断记录集是否为空。如果检索到记录尾,没有找到符合条件的记录,那么将弹出提示信息。主要程序代码如下:
?php
$txt_sel=$_POST[txt_sel];
$txt_tj=$_POST[txt_tj];
$txt_book=$_POST[txt_book];
if ($_POST[Submit]=="查询"){
if($_POST[txt_tj]=="like"){ //如果选择的条件为"like",则进行模糊查询
$sql=mysql_query("select * from tab_book where ".$txt_sel." like '%".$txt_book."%'");
$info=mysql_fetch_array($sql);
}
if($_POST[txt_tj]=="="){
$sql=mysql_query("select * from tab_book where ".$txt_sel." = '".$txt_book."'");
$info=mysql_fetch_array($sql);
}
if($_POST[txt_tj]==">"){
$sql=mysql_query("select * from tab_book where ".$txt_sel." > '".$txt_book."'");
$info=mysql_fetch_array($sql);
}
if($_POST[txt_tj]=="
$sql=mysql_query("select * from tab_book where ".$txt_sel."
$info=mysql_fetch_array($sql);
}
else{
if($info==false){ //如果检索的信息不存在,则输出相应的提示信息
echo "
}
}
}
?>
注意:本范例在实现模糊查询时,使用了通配符“%”。“%”表示任意零个或多个字符。
(3)利用Do…While循环语句以表格形式输出数据信息到浏览器中。代码如下:
do{
?>
}
while($info=mysql_fetch_array($sql));
?>
查询指定时间段的数据
在对日期数据进行查询时,经常需要对某一时间段内的数据进行查询。首先介绍一个简单的日期查询。
例如,利用SQL语句查询采购信息表中指定时间的采购信息,代码如下:
$sql=mysql_query("select * from tb_cgdan where cgdate >'2007-01-12'");
$result=mysql_fetch_array($sql);
利用SQL语句中的BETWEEN…AND语句可以实现时间段查询的功能。
BETWEEN…AND语句的语法格式如下:
test_expression [ NOT ] BETWEEN begin_expression AND end_expression
test_expression:用来在由begin_expression和end_expression定义的范围内进行测试的表达式。
NOT:指定谓词的结果被取反。
begin_expression:任何有效的表达式。
begin_expression为时间段的起始日期。
end_expression:任何有效的表达式。
test_expression为时间段的终止日期。
AND:作为一个占位符,表示test_expression应该处于由begin_expression和end_expression指定的范围内。
下面详细介绍对指定时间段内数据记录进行查询的方法。
范例09-05 查询指定时间段的数据 |
|
|
本范例的实现过程如下。
(1)利用include包含文件命令引用数据库配置文件访问数据库。代码如下:
(2)利用复合条件BETWEEN…AND语句检索指定时间段内的商品采购信息,主要程序代码如下:
if($_POST["subb"]""){
$_SESSION["sdate"]=$_POST["sdate"];
$_SESSION["edate"]=$_POST["edate"];
$sql=mysql_query("select * from tb_cgdan where cgdate between '".$_SESSION["sdate"]."' and '".$_SESSION ["edate"]."'");
$result=mysql_fetch_array($sql);
if($result==false){
echo "
}
?>
(3)利用Do…While循环输出语句将符合条件的采购信息输出到浏览器中,代码如下:
do{
?>
}while($result=mysql_fetch_array($sql));
}
mysql_close();
?>
查询畅销的前5种商品
要查询出最畅销的商品,必须利用ORDER BY子句根据一个或一个以上的字段来排序查询结果,然后再使用LIMIT子句限制Select语句返回的行数。LIMIT取1个或2个参数,如果给定2个参数,第一个参数用于指定要返回的第一行的偏移量,第二个参数用于指定返回行的最大数目。初始行的偏移量是0(不是1)。
mysql> select * from table LIMIT 5,10; # Retrieve rows 6-15
如果给定一个参数,它指出返回行的最大数目。
mysql> select * from table LIMIT 5; # Retrieve first 5 rows
即LIMIT n等价于LIMIT 0,n。
数据查询有一项极为重要的功能,那就是它能够查询出最前面的或最后的。下面通过具体的范例进行讲解。
范例09-06 查询畅销的前5种商品 |
|
|
查询时不仅可以查询具有相同字段信息的记录,还可以对某一特定范围内的数据信息进行查询。运行本范例,如图9.10所示,默认页显示tb_stocks数据表中的全部信息。单击【查询】按钮,即可统计出最畅销的前5种商品(本范例按销售总量降序排列,再返回查询结果的前5条记录)并将结果输出到浏览器
(1)利用框架嵌套技术布局范例页面,代码如下:
(2)利用include包含文件命令引用数据库配置文件访问数据库。代码如下:
(3)创建记录集。利用LIMIT 5子句返回满足Where子句的前5条记录,代码如下:
if ($_POST[subb]=="查询"){
$sql=mysql_query("select spname,cd,dw,price,sum(xssl) as sum_xssl,sum(xsje) as sum_xsje from tb_ stocks group by spname,cd,dw,price order by sum_xssl desc LIMIT 5");
$result=mysql_fetch_array($sql);
}
?>
(4)利用Do…While循环语句输出查询结果,代码如下:
do{
?>
}while($result=mysql_fetch_array($sql));
?>
多表分组统计商品的销售情况
在查询统计中经常会遇到对查询结果进行排序、分组的情况。多表分组统计主要应用了SUM聚集函数,该函数主要用于返回表达式中所有值的和,或只返回DISTINCT值。需要说明的是,SUM聚集函数只能用于数据类型是数字的列,且忽略NULL值。
语法如下:
SUM ( [ALL|DISTINCT] expression )
其中,参数ALL表示对所有的值进行聚集函数运算,是默认值;参数DISTINCT用于指定SUM返回惟一值的和;参数expression是常量、列或函数,或者是算术、按位与字符串等运算符的任意组合。expression是精确数字或近似数字数据类型分类(bit数据类型除外)的表达式。其他情况下不允许使用聚集函数和子查询。
说明:SUM函数在对列中数值相加时忽略NULL值。但是,如果列中的所有值均为NULL,则SUM函数返回NULL作为其结果。
下面通过具体的范例详细讲解多表分组统计的应用。
范例09-07 多表分组统计商品的销售情况 |
|
|
本范例实现的是在商品销售信息表和商品库存信息表中查询商品的销售数量和现存数量,并按商品编号进行分组。运行本范例,单击【统计】按钮,即可将符合条件的统计结果输出到浏览器中
(1)利用include包含文件命令引用数据库配置文件访问数据库。代码如下:
(2)创建记录集。在图书销售信息表和图书库存信息表中查询图书的销售数量和现存数量,并按图书编码、图书名称、作者等分组,从而实现从多个表中分组统计数据信息。主要程序代码如下:
if ($_POST[subb]=="统计"){
$sql=mysql_query("select k.spid,k.spname,k.kcsl,sum(x.xssl) as sum_xssl from tb_stocks as k,tb_market as x where k.spid=x.spid group by k.spid,k.spname,k.kcsl");
$result=mysql_fetch_array($sql);
}
?>
(3)利用Do…While语句循环输出统计后的商品库存信息和销售信息。代码如下:
}while($result=mysql_fetch_array($sql));
mysql_close();
?>

MySQL在數據庫和編程中的地位非常重要,它是一個開源的關係型數據庫管理系統,廣泛應用於各種應用場景。 1)MySQL提供高效的數據存儲、組織和檢索功能,支持Web、移動和企業級系統。 2)它使用客戶端-服務器架構,支持多種存儲引擎和索引優化。 3)基本用法包括創建表和插入數據,高級用法涉及多表JOIN和復雜查詢。 4)常見問題如SQL語法錯誤和性能問題可以通過EXPLAIN命令和慢查詢日誌調試。 5)性能優化方法包括合理使用索引、優化查詢和使用緩存,最佳實踐包括使用事務和PreparedStatemen

MySQL適合小型和大型企業。 1)小型企業可使用MySQL進行基本數據管理,如存儲客戶信息。 2)大型企業可利用MySQL處理海量數據和復雜業務邏輯,優化查詢性能和事務處理。

InnoDB通過Next-KeyLocking機制有效防止幻讀。 1)Next-KeyLocking結合行鎖和間隙鎖,鎖定記錄及其間隙,防止新記錄插入。 2)在實際應用中,通過優化查詢和調整隔離級別,可以減少鎖競爭,提高並發性能。

MySQL不是一門編程語言,但其查詢語言SQL具備編程語言的特性:1.SQL支持條件判斷、循環和變量操作;2.通過存儲過程、觸發器和函數,用戶可以在數據庫中執行複雜邏輯操作。

MySQL是一種開源的關係型數據庫管理系統,主要用於快速、可靠地存儲和檢索數據。其工作原理包括客戶端請求、查詢解析、執行查詢和返回結果。使用示例包括創建表、插入和查詢數據,以及高級功能如JOIN操作。常見錯誤涉及SQL語法、數據類型和權限問題,優化建議包括使用索引、優化查詢和分錶分區。

MySQL是一個開源的關係型數據庫管理系統,適用於數據存儲、管理、查詢和安全。 1.它支持多種操作系統,廣泛應用於Web應用等領域。 2.通過客戶端-服務器架構和不同存儲引擎,MySQL高效處理數據。 3.基本用法包括創建數據庫和表,插入、查詢和更新數據。 4.高級用法涉及復雜查詢和存儲過程。 5.常見錯誤可通過EXPLAIN語句調試。 6.性能優化包括合理使用索引和優化查詢語句。

選擇MySQL的原因是其性能、可靠性、易用性和社區支持。 1.MySQL提供高效的數據存儲和檢索功能,支持多種數據類型和高級查詢操作。 2.採用客戶端-服務器架構和多種存儲引擎,支持事務和查詢優化。 3.易於使用,支持多種操作系統和編程語言。 4.擁有強大的社區支持,提供豐富的資源和解決方案。

InnoDB的鎖機制包括共享鎖、排他鎖、意向鎖、記錄鎖、間隙鎖和下一個鍵鎖。 1.共享鎖允許事務讀取數據而不阻止其他事務讀取。 2.排他鎖阻止其他事務讀取和修改數據。 3.意向鎖優化鎖效率。 4.記錄鎖鎖定索引記錄。 5.間隙鎖鎖定索引記錄間隙。 6.下一個鍵鎖是記錄鎖和間隙鎖的組合,確保數據一致性。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Dreamweaver CS6
視覺化網頁開發工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

禪工作室 13.0.1
強大的PHP整合開發環境

WebStorm Mac版
好用的JavaScript開發工具