网管联盟 | 网管论坛 | 网管u家 | 网管博客 | 网管软件 | 网管求职 | 小游戏 | 网管搜索 | 网管原创 | 网管聚合 | 网管读摘 | 网管焦点 | 世界素材 | 会员投稿 | 会员中心 
中国网管联盟
Windows Linux Cisco 网络技术 数据库 黑客攻防 DotNet Java PHP 认证 新闻资讯 服务器 存储资讯 网络设备 网管学堂 技术专题 焦点 网吧频道
 当前位置: > bitsCN.com > 数据库技术 > Mysql > PHP-MySQL > 多条件查询  

多条件查询

2006-02-27  作者:bitsCN整理  来源:中国网管联盟  点评 投稿 收藏

有关多条件查询的问题,以前我在论坛发过帖子,前几天有网友对此感兴趣,我就花了点时间整理了一下,其实并没有什么特别的,关键在于写出正确的SQL查询语句,由于各人所用数据库不同,而SQL语句是相同的。所以在此我仅给出根据多个条件自动生成的符合要求的SQL语句。对条件的数目基本没有限制,不超过数组的组元数目就可以了。
说白了,其实就是字符串的游戏。拼拼凑凑而已。这里使用数组储存条件和查询语句,程序也不长,有详细的注释,不会化您多少功夫的。呵呵。
在conditions_search.html中输入您的查询条件,点击查询。您输入的条件在提交到display_search_SQL.php进行处理后,将给出合适的SQL语句。


/***************conditions_search.html****************/
<html>
<head>
<title>Conditions_Search多条件查询</title>
</head>
<body> 网管bitscn_com
Conditions_Search多条件查询:
<form name="form1" method="post" action="display_search_SQL.php">
Condition1:<input type="text" name="condition1"><br>
Condition2:<input type="text" name="condition2"><br>
Condition3:<input type="text" name="condition3"><br>
Condition4:<select name="condition4">
<option value='' selected>all</option>
<option value='red'>red</option>
</select><br>
<input type='submit' name='search' value='查询'>
</form>
</body>
</html>
/***************conditions_search.html**********************/


/***************display_search_SQL.php*********************/
<?//从conditions_search.html接收到四个条件, 网管论坛bbs_bitsCN_com
//condition1,condition2,condition3,condition4。
//其中有文本框输入的字符串,有列表框下拉选择的,
//这些接收条件的方式都不重要。
//条件还可以增加(没什么限制,当然也不要太大,超过数组的上限)。
//以下有几点注意:
//认为条件值为空时,不限制;
//要查询的表名为testtable;
//condition1对应的字段名为column1……
//

$ConditionsNumber=4; //共有4个条件。(可改为实际使用的条件数)
$ConditionsArray=array("$condition1","$condition2","$condition3","$condition4");
//把各个条件排入一个数组中,方便下面循环。(数组很容易扩充)
$SearchSQLArray=array(" where column1='$condition1'"," where column2 like '%$condition2%'"," where column3='$condition3'"," where column4='$condition4'");
//预写好一些SQL语句,下面再根据情况处理。(数组很容易扩充)

for($i=0;$i<$ConditionsNumber;$i++) 网管u家u.bitscn@com
{
if($ConditionsArray[$i]=="")
$SearchSQLArray[$i]="";
//第一步处理:如果条件值为空,相应的SQL语句为空。
$haveWhere=false; //设“存在where”检查标志的初值为false。
for($j=0;$j<$i;$j++)
//从开始到目前循环的i,处理有哪些where
//需要变为and。
{
$wherePosition=strpos($SearchSQLArray[$j],"where");
//检查i前面是否有where出现。
if(($wherePosition=="1")&&($haveWhere==false))
{
$SearchSQLArray[$i]=ereg_replace("where","and",$SearchSQLArray[$i]);
//where的位置为1,且前面已有where。
//则where换成and。
$haveWhere=true; //"存在where”检查标志设为true。
}
}
};

for($i=0;$i<$ConditionsNumber;$i++)
中国网管论坛bbs.bitsCN.com

$sql=$sql.$SearchSQLArray[$i];
$sql="select * from mytable".$sql.";";
//组成SQL语句
echo $sql;
?>
/**************display_search_SQL.php*********************/


摘自:<a href=http://phpuser.com/tips_and_tricks/detail.php?id=126>PHP中文用户</a>

 上一篇:用 PHP+MYSQL 实现论坛里的分级+分页显示   下一篇:很好用的PHP数据库类
多条件查询 评论:
loading.. 评论加载中…
评论:请自觉遵守互联网相关政策法规,评论不得超过250字。

验证码: 注册用户
本类热门排行:
最新推荐文章:
网管论坛交流: