音效素材网提供各类素材,打造精品素材网站!

站内导航 站长工具 投稿中心 手机访问

音效素材

PHP模糊查询技术实例分析【附源码下载】
日期:2021-09-06 20:27:05   来源:脚本之家

本文实例讲述了PHP模糊查询技术。分享给大家供大家参考,具体如下:

简介

  • 从本质上揭密PHP模糊查询技术

功能

  • 根据输入的关键字查找相关用户

PHP用户查询器案例分析

课程目标

  • 掌握PHP模糊技术的应用

课程重点

  • PHP模糊查询的语法
  • PHP模糊查询的应用

课程案例(效果图)

数据库设计

用户表(user):

CREATE TABLE user(
  `uid` int(10) AUTO_INCREMENT PRIMARY KEY COMMENT '用户ID',
  `username` varchar(30) NOT NULL DEFAULT '' COMMENT '用户名',
  `password` varchar(6) NOT NULL DEFAULT '' COMMENT '密码',
  `sex` char(2) NOT NULL DEFAULT '保密' COMMENT '性别',
  `email` varchar(40) NOT NULL DEFAULT '' COMMENT '邮箱',
  `hobby` varchar(255) NOT NULL DEFAULT '' COMMENT '兴趣爱好',
  KEY `username`(`username`)//索引
)ENGINE=MyISAM DEFAULT CHARSET=UTF8 COMMENT='用户表'

索引的好处:

如果按照某个条件去检索数据,如果这个条件字段没有建立索引,查询的时候是会遍历整张表,如果你建立了索引,查询的时候就会根据索引来查询,进而提高查询性能

Mysql模糊查询语法

  • SQL匹配模式(开发中应用最多的一种)
  • 正则表达式匹配模式

SQL匹配模式

  • 使用SQL匹配模式,不能使用操作符=或者!=,而是使用操作符LIKE或者NOT LIKE
  • 使用SQL匹配模式,MYSQL提供两种通配符:
    ①%表示任意数量的任意字符(其中包含0个)
    ②_表示的任意单个字符
  • 使用SQL匹配模式,如果匹配格式中不包含以上两种通配符的任意一个,其查询效果等同于=或者!=
  • 使用SQL匹配模式,默认情况下不区分大小写

代码实现:

SELECT * FROM user WHERE username like 'l%';
SELECT * FROM user WHERE username like '%e';
SELECT * FROM user WHERE username like '%o%';
SELECT * FROM user WHERE username like '___';//三个_,表示username为三个字符的结果集
SELECT * FROM user WHERE username like '_o%';//第二个字符为o

正则表达式匹配模式

  • . 匹配任意单个字符
  • * 匹配0个或多个在他前面的字符

eg:x* 表示匹配任何数量的x字符

  • [] 匹配括号中的任意字符

eg:[abc] 匹配字符a、b后者c
   [a-z] 匹配任何字母
   [0-9] 匹配任何数字
   [0-9]* 匹配任何数量的任何数字
   [a-z]* 匹配任何数量的任何字母

  • ^ 表示以某个字符或者字符串开头

eg:^a 表示以字母a开头

  • $ 表示已某个字符或者字符串结果

eg:s$ 表示以字母s结尾

  • 使用正则表达式匹配模式使用的操作符:REGEXP(RLIKE) 或者NOT REGEXP(NOT RLIKE)

code:

SELECT * FROM user WHERE username REGEXP '^l';
SELECT * FROM user WHERE username REGEXP '...';

PS:如果仅使用.通配符,有几个点通配符,假设N个,那么匹配模式表示大于等于N个

  • 精确字符数

^...$          //表示只能为三个字符
SELECT * FROM user WHERE username REGEXP '^...$';

案例

开发流程

源码分析

<?php
//关键字
$keywords = isset($_POST['keywords'])?$_POST['keywords']:'';
//连接数据库,php7废弃了mysql_connect推荐使用mysqli_connect
$link = mysqli_connect(
  "localhost:3306",
  "root",
  "root",
  "mook"
);
if(!empty($keywords)){
  $sql = "SELECT * FROM user WHERE username like '%{$keywords}%' ";
}else{
  $sql = "SELECT * FROM user";
}
$usersArr = [];
$result = $link->query($sql);
while($row = $result->fetch_assoc())
{
  //简单高亮显示
  // $row['username'] = str_replace($keywords, "<font color='red'>".$keywords."</font>",$row['username']);
  //高亮显示,不区分关键字的大小写
  $usernameArr = preg_split('/(?<!^)(?!$)/u',$row['username']);
  foreach ($usernameArr as $key => $value) {
    if(strtoupper($keywords) == strtoupper($value)){
      $usernameArr[$key] = "<font color='red'>".$value."</font>";
    }
  }
  $row['username'] = join($usernameArr);
  $usersArr[] = $row;
}
?>
<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>php用户查询器</title>
</head>
<body>
  <h1>php模糊查询</h1>
  <form action="index.php" method="post">
    用户名:<input type="text" name="keywords" value="" />
    <input type="submit" value="提交查询" />
  </form>
  <?php
    if(!empty($keywords)){
      echo "查询关键词:<font color='red'>&nbsp;".$keywords."&nbsp;</font>结果!";
    }
    $tableString = "<table width='500' border='1' cellpadding='5'>";
    $tableString .= "<tr bgcolor='orange'><th>用户名</th><th>邮箱</th><th>性别</th></tr>";
    if(!empty($usersArr)){
      foreach ($usersArr as $key => $value) {
        $tableString .= "<tr><td>" . $value['username']. "</td><td>" . $value['email'] . "</td><td>".$value['sex']."</td></tr>";
      }
    }else{
      $tableString .="<tr><td colspan='3'>没有数据</td></tr>";
    }
    $tableString .= "</table>";
    echo $tableString;
  ?>
</body>
</html>

源码下载地址:

点击此处本站下载

希望本文所述对大家PHP程序设计有所帮助。

    您感兴趣的教程

    在docker中安装mysql详解

    本篇文章主要介绍了在docker中安装mysql详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编...

    详解 安装 docker mysql

    win10中文输入法仅在桌面显示怎么办?

    win10中文输入法仅在桌面显示怎么办?

    win10系统使用搜狗,QQ输入法只有在显示桌面的时候才出来,在使用其他程序输入框里面却只能输入字母数字,win10中...

    win10 中文输入法

    一分钟掌握linux系统目录结构

    这篇文章主要介绍了linux系统目录结构,通过结构图和多张表格了解linux系统目录结构,感兴趣的小伙伴们可以参考一...

    结构 目录 系统 linux

    PHP程序员玩转Linux系列 Linux和Windows安装

    这篇文章主要为大家详细介绍了PHP程序员玩转Linux系列文章,Linux和Windows安装nginx教程,具有一定的参考价值,感兴趣...

    玩转 程序员 安装 系列 PHP

    win10怎么安装杜比音效Doby V4.1 win10安装杜

    第四代杜比®家庭影院®技术包含了一整套协同工作的技术,让PC 发出清晰的环绕声同时第四代杜比家庭影院技术...

    win10杜比音效

    纯CSS实现iOS风格打开关闭选择框功能

    这篇文章主要介绍了纯CSS实现iOS风格打开关闭选择框,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作...

    css ios c

    Win7如何给C盘扩容 Win7系统电脑C盘扩容的办法

    Win7如何给C盘扩容 Win7系统电脑C盘扩容的

    Win7给电脑C盘扩容的办法大家知道吗?当系统分区C盘空间不足时,就需要给它扩容了,如果不管,C盘没有足够的空间...

    Win7 C盘 扩容

    百度推广竞品词的投放策略

    SEM是基于关键词搜索的营销活动。作为推广人员,我们所做的工作,就是打理成千上万的关键词,关注它们的质量度...

    百度推广 竞品词

    Visual Studio Code(vscode) git的使用教程

    这篇文章主要介绍了详解Visual Studio Code(vscode) git的使用,小编觉得挺不错的,现在分享给大家,也给大家做个参考。...

    教程 Studio Visual Code git

    七牛云储存创始人分享七牛的创立故事与

    这篇文章主要介绍了七牛云储存创始人分享七牛的创立故事与对Go语言的应用,七牛选用Go语言这门新兴的编程语言进行...

    七牛 Go语言

    Win10预览版Mobile 10547即将发布 9月19日上午

    微软副总裁Gabriel Aul的Twitter透露了 Win10 Mobile预览版10536即将发布,他表示该版本已进入内部慢速版阶段,发布时间目...

    Win10 预览版

    HTML标签meta总结,HTML5 head meta 属性整理

    移动前端开发中添加一些webkit专属的HTML5头部标签,帮助浏览器更好解析HTML代码,更好地将移动web前端页面表现出来...

    移动端html5模拟长按事件的实现方法

    这篇文章主要介绍了移动端html5模拟长按事件的实现方法的相关资料,小编觉得挺不错的,现在分享给大家,也给大家...

    移动端 html5 长按

    HTML常用meta大全(推荐)

    这篇文章主要介绍了HTML常用meta大全(推荐),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参...

    cdr怎么把图片转换成位图? cdr图片转换为位图的教程

    cdr怎么把图片转换成位图? cdr图片转换为

    cdr怎么把图片转换成位图?cdr中插入的图片想要转换成位图,该怎么转换呢?下面我们就来看看cdr图片转换为位图的...

    cdr 图片 位图

    win10系统怎么录屏?win10系统自带录屏详细教程

    win10系统怎么录屏?win10系统自带录屏详细

    当我们是使用win10系统的时候,想要录制电脑上的画面,这时候有人会想到下个第三方软件,其实可以用电脑上的自带...

    win10 系统自带录屏 详细教程

    + 更多教程 +
    ASP编程JSP编程PHP编程.NET编程python编程