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

热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

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

热门文章

热工具

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

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

Go语言是一种高效、简洁且易于学习的编程语言,因其在并发编程和网络编程方面的优势而备受开发者青睐。在实际开发中,数据库操作是不可或缺的一部分,本文将介绍如何使用Go语言实现数据库的增删改查操作。在Go语言中,我们通常使用第三方库来操作数据库,比如常用的sql包、gorm等。这里以sql包为例介绍如何实现数据库的增删改查操作。假设我们使用的是MySQL数据库。

Hibernate多态映射可映射继承类到数据库,提供以下映射类型:joined-subclass:为子类创建单独表,包含父类所有列。table-per-class:为子类创建单独表,仅包含子类特有列。union-subclass:类似joined-subclass,但父类表联合所有子类列。

苹果公司最新发布的iOS18、iPadOS18以及macOSSequoia系统为Photos应用增添了一项重要功能,旨在帮助用户轻松恢复因各种原因丢失或损坏的照片和视频。这项新功能在Photos应用的"工具"部分引入了一个名为"已恢复"的相册,当用户设备中存在未纳入其照片库的图片或视频时,该相册将自动显示。"已恢复"相册的出现为因数据库损坏、相机应用未正确保存至照片库或第三方应用管理照片库时照片和视频丢失提供了解决方案。用户只需简单几步

如何在PHP中使用MySQLi建立数据库连接:包含MySQLi扩展(require_once)创建连接函数(functionconnect_to_db)调用连接函数($conn=connect_to_db())执行查询($result=$conn->query())关闭连接($conn->close())

PHP中处理数据库连接报错,可以使用以下步骤:使用mysqli_connect_errno()获取错误代码。使用mysqli_connect_error()获取错误消息。通过捕获并记录这些错误信息,可以轻松识别并解决数据库连接问题,确保应用程序的顺畅运行。

HTML无法直接读取数据库,但可以通过JavaScript和AJAX实现。其步骤包括建立数据库连接、发送查询、处理响应和更新页面。本文提供了利用JavaScript、AJAX和PHP来从MySQL数据库读取数据的实战示例,展示了如何在HTML页面中动态显示查询结果。该示例使用XMLHttpRequest建立数据库连接,发送查询并处理响应,从而将数据填充到页面元素中,实现了HTML读取数据库的功能。

PHP是一种广泛应用于网站开发的后端编程语言,它具有强大的数据库操作功能,常用于与MySQL等数据库进行交互。然而,由于中文字符编码的复杂性,在处理数据库中文乱码时常常会出现问题。本文将介绍PHP处理数据库中文乱码的技巧与实践,包括常见的乱码原因、解决方法和具体的代码示例。常见的乱码原因数据库字符集设置不正确:数据库在创建时需选择正确的字符集,如utf8或u

通过Go标准库database/sql包,可以连接到MySQL、PostgreSQL或SQLite等远程数据库:创建包含数据库连接信息的连接字符串。使用sql.Open()函数打开数据库连接。执行SQL查询和插入操作等数据库操作。使用defer关闭数据库连接以释放资源。
