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

酸性属性には、原子性、一貫性、分離、耐久性が含まれ、データベース設計の基礎です。 1.原子性は、トランザクションが完全に成功するか、完全に失敗することを保証します。 2.一貫性により、データベースがトランザクションの前後に一貫性を保証します。 3.分離により、トランザクションが互いに干渉しないようにします。 4.永続性により、トランザクションの提出後にデータが永久に保存されることが保証されます。

MySQLは、データベース管理システム(DBMS)であるだけでなく、プログラミング言語にも密接に関連しています。 1)DBMSとして、MySQLはデータを保存、整理、取得するために使用され、インデックスを最適化するとクエリのパフォーマンスが向上する可能性があります。 2)SQLとPythonに埋め込まれたプログラミング言語とSQLalchemyなどのORMツールを使用すると、操作を簡素化できます。 3)パフォーマンスの最適化には、インデックス、クエリ、キャッシュ、ライブラリ、テーブル分割、およびトランザクション管理が含まれます。

MySQLはSQLコマンドを使用してデータを管理します。 1.基本コマンドには、select、挿入、更新、削除が含まれます。 2。高度な使用には、参加、サブクエリ、および集計関数が含まれます。 3.一般的なエラーには、構文、ロジック、パフォーマンスの問題が含まれます。 4。最適化のヒントには、インデックスの使用、Select*の回避、制限の使用が含まれます。

MySQLは、データの保存と管理に適した効率的なリレーショナルデータベース管理システムです。その利点には、高性能クエリ、柔軟なトランザクション処理、豊富なデータ型が含まれます。実際のアプリケーションでは、MySQLはeコマースプラットフォーム、ソーシャルネットワーク、コンテンツ管理システムでよく使用されますが、パフォーマンスの最適化、データセキュリティ、スケーラビリティに注意を払う必要があります。

SQLとMySQLの関係は、標準言語と特定の実装との関係です。 1.SQLは、リレーショナルデータベースの管理と操作に使用される標準言語であり、データの追加、削除、変更、クエリを可能にします。 2.MYSQLは、SQLを運用言語として使用し、効率的なデータストレージと管理を提供する特定のデータベース管理システムです。

INNODBは、レドログと非論的なものを使用して、データの一貫性と信頼性を確保しています。 1.レドログは、クラッシュの回復とトランザクションの持続性を確保するために、データページの変更を記録します。 2.Undologsは、元のデータ値を記録し、トランザクションロールバックとMVCCをサポートします。

説明コマンドのキーメトリックには、タイプ、キー、行、および追加が含まれます。 1)タイプは、クエリのアクセスタイプを反映しています。値が高いほど、constなどの効率が高くなります。 2)キーは使用されているインデックスを表示し、nullはインデックスがないことを示します。 3)行はスキャンされた行の数を推定し、クエリのパフォーマンスに影響します。 4)追加の情報を最適化する必要があるというFilesortプロンプトを使用するなど、追加情報を提供します。

Temporaryを使用すると、MySQLクエリに一時テーブルを作成する必要があることが示されています。これは、異なる列、またはインデックスされていない列を使用して順番に一般的に見られます。インデックスの発生を回避し、クエリを書き直し、クエリのパフォーマンスを改善できます。具体的には、expliect出力に使用を使用する場合、MySQLがクエリを処理するために一時テーブルを作成する必要があることを意味します。これは通常、次の場合に発生します。1)個別またはグループビーを使用する場合の重複排除またはグループ化。 2)Orderbyに非インデックス列が含まれているときに並べ替えます。 3)複雑なサブクエリを使用するか、操作に参加します。最適化方法には以下が含まれます。1)OrderbyとGroupB


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境
