在数据库中,数据查询是通过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();
?>

InnoDB使用redologs和undologs确保数据一致性和可靠性。1.redologs记录数据页修改,确保崩溃恢复和事务持久性。2.undologs记录数据原始值,支持事务回滚和MVCC。

EXPLAIN命令的关键指标包括type、key、rows和Extra。1)type反映查询的访问类型,值越高效率越高,如const优于ALL。2)key显示使用的索引,NULL表示无索引。3)rows预估扫描行数,影响查询性能。4)Extra提供额外信息,如Usingfilesort提示需要优化。

Usingtemporary在MySQL查询中表示需要创建临时表,常见于使用DISTINCT、GROUPBY或非索引列的ORDERBY。可以通过优化索引和重写查询避免其出现,提升查询性能。具体来说,Usingtemporary出现在EXPLAIN输出中时,意味着MySQL需要创建临时表来处理查询。这通常发生在以下情况:1)使用DISTINCT或GROUPBY时进行去重或分组;2)ORDERBY包含非索引列时进行排序;3)使用复杂的子查询或联接操作。优化方法包括:1)为ORDERBY和GROUPB

MySQL/InnoDB支持四种事务隔离级别:ReadUncommitted、ReadCommitted、RepeatableRead和Serializable。1.ReadUncommitted允许读取未提交数据,可能导致脏读。2.ReadCommitted避免脏读,但可能发生不可重复读。3.RepeatableRead是默认级别,避免脏读和不可重复读,但可能发生幻读。4.Serializable避免所有并发问题,但降低并发性。选择合适的隔离级别需平衡数据一致性和性能需求。

MySQL适合Web应用和内容管理系统,因其开源、高性能和易用性而受欢迎。1)与PostgreSQL相比,MySQL在简单查询和高并发读操作上表现更好。2)相较Oracle,MySQL因开源和低成本更受中小企业青睐。3)对比MicrosoftSQLServer,MySQL更适合跨平台应用。4)与MongoDB不同,MySQL更适用于结构化数据和事务处理。

MySQL索引基数对查询性能有显着影响:1.高基数索引能更有效地缩小数据范围,提高查询效率;2.低基数索引可能导致全表扫描,降低查询性能;3.在联合索引中,应将高基数列放在前面以优化查询。

MySQL学习路径包括基础知识、核心概念、使用示例和优化技巧。1)了解表、行、列、SQL查询等基础概念。2)学习MySQL的定义、工作原理和优势。3)掌握基本CRUD操作和高级用法,如索引和存储过程。4)熟悉常见错误调试和性能优化建议,如合理使用索引和优化查询。通过这些步骤,你将全面掌握MySQL的使用和优化。

MySQL在现实世界的应用包括基础数据库设计和复杂查询优化。1)基本用法:用于存储和管理用户数据,如插入、查询、更新和删除用户信息。2)高级用法:处理复杂业务逻辑,如电子商务平台的订单和库存管理。3)性能优化:通过合理使用索引、分区表和查询缓存来提升性能。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

Dreamweaver Mac版
视觉化网页开发工具

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

记事本++7.3.1
好用且免费的代码编辑器

Atom编辑器mac版下载
最流行的的开源编辑器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。