如何做模糊查询php,突然发现用PHP做多条件模糊查询很简单

原文:http://blog.csdn.net/suleil1/article/details/49471099

所使用的方法:$sqlArr=array();array_push();implode();

原理,

一、建立sql语句前半句,并且建立一个空数组。

二、根据条件是否为空来判断是否向数组中添加元素。如果不为空,使用array_push()方法来添加,第一个参数为数组名称,第二个参数为值。

三、全部条件判断完毕用implode()方法来拆分数组。第一个参数为使用什么字符来拆分,可以为字符串,第二个参数为数组。

四、加上sql语句后半句。完成sql语句!

五、PHP新版本只能这样用了:

SELECT name FROM dev WHERE name REGEXP 'PHP|SQL'; // REGEXP 'PHP|SQL|...'

例如:

$sql="select * from member where member_Type=0 and (";

$sqlArr=array();

if($member_id!="")

array_push($sqlArr," id like '$member_id' ");

if($member_Name!="")

array_push($sqlArr," member_Name like '%$member_Name%' ");

if($member_Creation!="")

array_push($sqlArr," member_Creation>'%$member_Creation%'");

$sql.=implode(" or ",$sqlArr);

$sql.=") order by id desc";$rs=mysql_query($sql);

$total=mysql_num_rows($rs);

$totalpage=ceil($total/$PageSize);

if($page>$totalpage)

$page=$totalpage;

$sql="select * from member where member_Type=0 and (";

$sqlArr=array();

if($member_id!="")

array_push($sqlArr," id like '$member_id' ");

if($member_Name!="")

array_push($sqlArr," member_Name like '%$member_Name%' ");

if($member_Creation!="")

array_push($sqlArr," member_Creation>'%$member_Creation%'");

$sql.=implode(" or ",$sqlArr);

$sql.=") order by id desc limit ".($page-1)*$PageSize.",".$PageSize;

这样,所有的参数都可以添加进来。

JSP+Servlet+javabean+oracle实现页面多条件模糊查询

之前写过一篇JSP+Servlet+javabean+mysql实现页面多条件模糊查询 使用的是mysql进行的分页查询,mysql用limit控制,而oracle则是用rownum,今天第一次写or ...

asp下实现多条件模糊查询SQL语句

常写一个简单的模糊查询的SQL语句格式可以如下例: sql="select * from 表名 where 字段名 like ’%" & request.form(&quo ...

ASP.NET MVC+EF框架+EasyUI实现权限管理系列(20)-多条件模糊查询和回收站还原的实现

原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(20)-多条件模糊查询和回收站还原的实现 ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇)   (1):框架 ...

实现多条件模糊查询SQL语句

很多网友问到如何写模糊查询语句和多条件查询,这里我整理了一下,假设以姓名.性别.电话号...作为数据库中的字段名. 通常写一个简单的模糊查询的SQL语句格式可以如下例: sql="selec ...

mongoose多条件模糊查询实例

mongoose多条件模糊查询 这是今天手头项目中遇到的一个问题,关于mongoose如何实现类似于SQL中 nick LIKE '%keyword%' or email LIKE '%keyword ...

thinkphp5.0多条件模糊查询以及多条件查询带分页如何保留参数

1,多条件模糊查询 等于:map[‘id′]=array(‘eq′,100);不等于:map[‘id′]=array(‘eq′,100);不等于:map[‘id’] = array(‘neq’,100 ...

laravel多条件模糊查询

1.运用cmd在项目根目录下创建路由组 php artisan make:controller queryController --resource 1.1数据库信息(student) CREATE ...

JSP+Servlet+javabean+mysql实现页面多条件模糊查询

需求: 一般列表页上面会有一个查询框,有各种的查询条件组合,一般都采用模糊查询方式 ,以下以自己做的实例来说明一下实现方法: 需要实现的界面原型:要满足条件: 1.单选分类,点GO按扭 2.单独输入标 ...

【转】SQL多条件模糊查询解决方案-存储过程

前言:   算法的基本特性在前几篇博客中已经做了详细的说明,经过不断的改进优化,到归仓的时候了,也就是说,该算法告一段落,不再更新. 作为最终的解决方案,简要的总结一下算法特性,以方便读者参阅. l ...

随机推荐

hadoop 安装教程 转载

hadoop2.2安装教程:http://www.aboutyun.com/thread-7684-1-1.html hadoop2.X使用手册1:通过web端口查看主节点.slave1节点及集群运行 ...

Maven web项目三种运行方式

http://www.micmiu.com/software/build/maven-web-eclipse-deploy/

ArrayList/Vector的原理、线程安全和迭代Fail-Fast

疑问 * ArrayList是非线程非安全的,具体是指什么?具体会产生什么问题?* ArrayList的内部原理是什么?为什么可以动态扩容?* Vector是线程安全的,具体是如何实现的?为什么不再推 ...

loj 1108(spfa判负环)

题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=26823 思路:题目的意思是求出所有的能够到达负环的点.负环很好求, ...

防止aspx木马的IIS SPY变态功能

防止aspx木马的IIS SPY变态功能 如果服务器支持aspx语言,而且被上传了aspx木马,利用木马里面的IIS SPY 功能,可以读出IIS里面的所有用户的密码,包括用IIS做FTP的,也能读出 ...

SpriteBuilder中频繁的切换场景层的解决办法

注意,不像SettingsLayer,CCScrollView实例并没有从场景中删除和重新加载像代码所示的那样. 你只是简单的改变其可视(visible)状态on和off. 改变可视状态比加载CCB或 ...

C++第三章复习与总结(思维导图分享)

在完成了第三章的学习后,为了便于日后的复习整理,我制作了一张思维导图,有需要的可以自取. 函数的定义与使用 带默认值的函数 在C++中我们可以为函数添加默认的参数值,在调用时可不传入或部分传入参数,为 ...

9;XHTML 多媒体

1.FLASH 动画的插入 2.MP3 及 WMV 视频的插入 3.网络流媒体视频的插入 使用 Web 如此流行的原因之一是可以再网页上加入图像.声音.动画和电影文件.虽然 过去对这些文件大小的限制局 ...

mysqldump参数详细说明

Mysqldump参数大全(参数来源于mysql5.5.19源码)   参数 参数说明 --all-databases  , -A 导出全部数据库. mysqldump  -uroot -p --al ...

数据库中truncate与delete的区别与联系

昨天被问到truncate与delete的区别,truncate没用过,回去百度了一下,才知道还有这个一种语句. truncate table命令将快速删除数据表中的所有记录(保留数据表结构).这种快 ...

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值