本文实例讲述了php+mysql+ajax实现单表多字段多关键词查询的方法。分享给大家供大家参考,具体如下:
单表多字段查询在一些稍微复杂一点的查询中十分有用。这里主要利用MySQL数据库中的concat函数实现单表多字段多关键词查询。并且显示查询结果的表格可根据所选数据表动态生成。
html代码:
$(function(){
//回车提交查询
$('#queryBox').keydown(function(e){
if(e.keyCode == 13)
{
$("#query").focus();//查询按钮获得焦点
$("#query").click();//调用点击提交按钮
}
});
//点击查询按钮
$("#query").click(function(){
//获取用户选择的数据表和查询关键词
var queryType=$("#queryType").val().trim();
var queryKeywords=$("#queryKeywords").val().trim();
//对查询关系词的内容进行限制,比如只能输入汉字、字母、数字和空格。
var reg=/^[ a-zA-Z0-9\u4e00-\u9fa5]+$/;
if(reg.test(queryKeywords)==false)
{
$("#queryTip").text("您输入的关键词有部分内容不符合要求,只能输入汉字、字母、数字和空格。");
}
//如果内容检测通过,开始提交查询
else
{
if(queryType!="" && queryKeywords!="")
{
$("#queryTip").text("正在为您检索,请稍候……");
//使用ajax访问php页面进行查询
$.ajax({
type:"post",
url:"queryInIndex.php",
async:true,
data:{queryType:$("#queryType").val(),queryKeywords:$("#queryKeywords").val()},
dataType:"json",
success:function(data){
if(data=="no")
{
$("#queryTip").text("没有找到您要查询的信息。");
}
else
{
$("#queryTip").text("为您找到 "+data.length+" 条信息。");
//预设结果表格字符名
if($("#queryType").val()=="users")
fieldsString="邮箱,姓名,英文名,学号,学位类型,导师,手机,房间";
else if($("#queryType").val()=="papers")
fieldsString="作者,标题,期刊/会议,卷期页,级别,状态";
else if($("#queryType").val()=="softwares")
fieldsString="作者,标题,登记号,日期";
else if($("#queryType").val()=="patents")
fieldsString="作者,标题,受理日期,受理号,授权日期,授权号";
//调用函数创建表格
createTable("queryResultList",data,fieldsString,"queryResultPager");
$("#queryKeywords").focus();// 关键词文本框继续获得焦点,以方便用户继续输入内容
}
}
});
}
else
{
$("#queryTip").text("请先选择查询类型,并输入关键词,然后点击查询按钮。");
$("#queryKeywords").focus();
}
}
})
function createTable(tableHolder,data,fieldsString,pagerHolder)
//自动创建结果表格的函数
/*
参数含义:
tableHolder:显示结果表格的父元素
data:JSON格式的查询结果
fieldsString:字段名字符串
pagerHolder:显示分页导航的元素
* */
{
fieldsArr=fieldsString.split(",");//对字段名字符串进行分割
var columnNum=fieldsArr.length; //获取列数
var rowNum=data.length;//获取行数
$('#'+tableHolder).html("");//清除现有表格
$('#'+tableHolder).append("queryInIndex.php:
运行结果截图:


更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP+ajax技巧与应用小结》、《PHP网络编程技巧总结》、《PHP基本语法入门教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家PHP程序设计有所帮助。
关注微信公众号获取更多VSCode编程信息,定时发布干货文章
全部评论