PHP高级检索功能的实现以及动态拼接sql

我们学习了解了这么多关于PHP的知识,不知道你们对PHP高级检索功能的实现以及动态拼接sql是否已经完全掌握了呢,如果没有,那就跟随本篇文章一起继续学习吧!

PHP高级检索功能的实现以及动态拼接sql。完成的功能有:可以单独根据一个条件查询,也可以通过多个条件综合查询,难点在于动态拼接sql。

完成的效果

总画面

单独根据姓名模糊查询

单独根据性别查询

根据多个条件综合查询

前台页面代码

php 复制代码
<form action="" method="post">
<labal>姓名:</labal> <input style="width:105px" type="text" name="search_name" id="search_name" placeholder="姓名">
&nbsp
<labal>性别:</labal>
<input type="radio" name="search_sex" id="man" value="0">男
<input type="radio" name="search_sex" id="women" value="1">女
&nbsp
<labal>年龄:</labal><input style="width:105px" type="text" name="search_age" id="add_age"placeholder="年龄">
&nbsp
<labal>邮箱:</labal><input style="width:150px" type="text" name="search_email" id="search_email" placeholder="邮箱">
<input id="b" name="submit" style="width:60px" type="submit" value="检索">
</form>

后台处理代码

php 复制代码
//接收用户输入的数据$name = $sex = $age = $email = "";if (isset($_POST['submit'])) {
    if (isset($_POST['search_name'])) {
    	$name = $_POST['search_name'];
    }
    if (isset($_POST['search_sex'])) {
    	$sex = $_POST['search_sex'];
    }
    if (isset($_POST['search_age'])) {
    	$age = $_POST['search_age'];
    }
    if (isset($_POST['search_email'])) {
    	$email = $_POST['search_email'];
    }//执行检索sql$search_sql = $myTest->searchData($name,$sex,$age,$email);$result = $myTest->sqlRun($search_sql);

动态拼接sql

php 复制代码
public function searchData($name,$sex,$age,$email){

		switch ($name) {
			//未输入姓名
			case null:
				$name_info='';
				break;
			     //根据姓名模糊查询
			    default:
				$name_info=" and name LIKE '%".$name."%'";
				break;
		}
		switch ($sex) {
			//未输入性别
			case null:
				$sex_info='';
				break;
			//根据性别准确查询
			default:
				$sex_info=' and sex='.$sex;
				break;
		}
		switch ($age) {
			//未输入年龄
			case null:
				$age_info='';
				break;
			//根据年龄准确查询
			default:
				$age_info=' and age='.$age;
				break;
		}
		switch ($email) {
			//未输入邮箱
			case null:
				$email_info='';
				break;
			//根据邮箱模糊查询
			default:
				$email_info=" and email LIKE '%".$email."%'";
				break;
		}$search_sql='SELECT * FROM users WHERE 1=1'.$name_info.$sex_info.$age_info.$email_info;'';return $search_sql;
	}
相关推荐
xiaoshuaishuai84 小时前
C# AvaloniaUI动态显示图片
开发语言·c#
日光明媚5 小时前
一步生成视频!One-Forcing:DMD + 零成本 GAN,训练 200 步超越多步 SOTA
android·开发语言·kotlin
2301_803538955 小时前
Java读取Word图片的两种实用方法
java·开发语言·word
AugustRed5 小时前
Linux 运维常用命令大全(超全速查表)
运维·网络·php
bug和崩溃我都要7 小时前
Qt 封装 libmpv 全功能视频播放器开发指南
开发语言·qt·音视频
郝学胜-神的一滴7 小时前
Qt 高级开发 018:复刻经典登录界面布局与窗口美化全解析
开发语言·c++·qt·程序人生·用户界面
郝亚军7 小时前
IEEE 754 单精度浮点的SEM表示
开发语言·c++·算法
zhangjw347 小时前
第15篇:Java多线程零基础入门,进程线程、线程创建方式、线程生命周期、线程安全彻底吃透
java·开发语言·面试
蝈理塘(/_\)大怨种7 小时前
类和对象 (上)
java·开发语言
小新1107 小时前
qt creator 将qInfo的输出日志写入日志文档,方便查看
开发语言·qt