`
baalwolf
  • 浏览: 350719 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

单表多字段MySQL模糊查询的实现

 
阅读更多

MySQL模糊查询是我们经常会遇到的,下面就为您介绍MySQL模糊查询的实现方法,希望对您学习MySQL模糊查询方面能够有所帮助。

在最近的一个项目需要实现在单表中对多字段进行多个关键字的MySQL模糊查询,但这数个关键字并不一定都存在于某个字段

例如现有table表,其中有title,tag,description三个字段,分别记录一条资料的标题,标签和介绍。然后根据用户输入的查询请求,将输入的字串通过空格分割为多个关键字,再在这三个字段中查询包含这些关键字的记录。

可目前遇到的问题是,这些关键字是可能存在于三个字段中的任意一个或者多个,但又要求三个字段必须包含所有的关键词。如果分别对每个字段进行模糊匹配,是没法实现所需的要求,由此想到两种方法:

在插入记录的同时,将需要进行多字段模糊查询的字段合并成一个字串并加入到一个新的字段中,然后对这个新字段进行模糊查询。

使用全文检索,但是这需要用到中文分词或者将汉字转化为拼音(拆分汉字是不可行的,MySQL默认FT最小字节为4),而且并不利于今后的维护。 
在网上爬了两天,对此问题的处理都没有找到满意的解决方法,最后在《MySQL权威指南》中翻到了CONCAT的使用方法,在书中的对CONCAT的描述是:

CONCAT(str1,str2,…)
返回值:由全体出入参数合并在一起而得到的字符串。只要输入的参数中有NULL值,就返回NULL。CONCAT允许只有一个输入参数的情况。

因此,前文的MySQL模糊查询可以通过下面这个SQL查询实现
SELECT * FROM `magazine` WHERE CONCAT(`title`,`tag`,`description`) LIKE ‘%关键字%’

分享到:
评论

相关推荐

    多字段 模糊查询 不要分

    在多字段模糊查询中,查询条件可以涉及数据表的多个字段,这样可以更全面地匹配用户的需求。 在数据库管理领域,SQL提供了多种模糊查询的语法。例如,`LIKE`操作符配合通配符`%`和`_`,可以实现模糊匹配。`%`代表...

    Mysql 时间模糊查询

    在MySQL中,模糊查询主要通过`LIKE`关键字实现。例如,查询所有包含“abc”的记录可以使用`SELECT * FROM table WHERE column LIKE '%abc%'`这样的语句。 #### 三、时间模糊查询的方法 ##### 1. Convert转成String...

    使用 Example 类 实现MySQL一个搜索框对多个字段的模糊查询

    本篇文章将详细介绍如何利用`Example`类实现对MySQL数据库中多个字段的模糊查询,以及与之相对的直接编写SQL语句的方式。 首先,`Example`类是MyBatis Generator自动生成的,它基于数据库表结构,提供了一种面向...

    浅谈MySQL模糊查询中通配符的转义

    sql中经常用like进行模糊查询,而模糊查询就要用到百分号“%”,下划线“_”这些通配符,其中“%”匹配任意多个字符,“_”匹配单个字符。如果我们想要模糊查询带有通配符的字符串,如“60%”,“user_name”,就...

    MySQL单表多关键字模糊查询的实现方法

    在最近的一个项目需要实现在MySQL单表多关键字模糊查询,但这数个关键字并不一定都存在于某个字段。例如现有table表,其中有title,tag,description三个字段,分别记录一条资料的标题,标签和介绍。然后根据用户...

    实现输入拼音或者简码模糊查询数据库某个字段的值

    本文将详细讲解如何使用C#语言实现拼音模糊查询功能,让用户仅输入一个字母就能查询到数据库中对应的完整字段。 首先,我们需要理解拼音模糊查询的基本原理。在中文环境下,由于汉字与拼音的对应关系,我们可以通过...

    MyBatis模糊查询

    模糊查询特别适用于文本数据的搜索,比如在姓名、地址或描述等字段中查找包含特定字符串的数据。 #### 三、MyBatis中实现模糊查询的方法 在MyBatis中实现模糊查询主要有两种方式:动态SQL和静态SQL。 ##### 1. ...

    自写php+MySQL模糊查询

    在这个场景中,"自写php+MySQL模糊查询" 是一个新手尝试实现的功能,它允许用户输入关键词,然后在数据库中进行不精确匹配,返回与关键词相关的记录。这样的功能可以极大地提高用户在网站上的搜索体验。以下是对这个...

    PHP+MySQL实现模糊查询员工信息功能示例

    本文实例讲述了PHP+MySQL实现模糊查询员工信息功能。分享给大家供大家参考,具体如下: 一、代码 注意两点: 1、用Notepad+编辑时,格式选择:【编码字符集】->【中文】->【gb2312】 2、 <meta ...

    数据库获取中文首字母自定义函数(字母查汉字模糊查询)

    这里,我们将深入探讨如何创建一个数据库自定义函数,实现“字母查汉字”和“模糊查询”的功能。 标题“数据库获取中文首字母自定义函数(字母查汉字模糊查询)”指的是在数据库系统中定义一个函数,该函数能接受...

    mysql模糊查询.docx

    【MySQL模糊查询】 在数据库操作中,模糊查询是一种常见的搜索技术,它允许用户使用通配符来匹配不完全知道的字符串。在MySQL中,我们主要使用`LIKE`、`NOT LIKE`、`INSTR`、`REGEXP`和`RLIKE`等关键字来进行模糊...

    mysql实现根据多个字段查找和置顶功能

    在MySQL数据库中,进行多字段查找和排序是常见的操作,特别是在数据检索和管理时。这里我们将深入探讨如何根据多个字段进行查找以及实现置顶功能。 首先,我们要理解基础的SQL查询语法。当需要根据单一字段排序时,...

    JAVA,多条件,模糊查询,多个条件同时查询显示结果

    在Java编程中,进行多条件和模糊查询是数据库操作中常见的需求,特别是在处理用户输入时,用户可能希望根据多个不同的标准来筛选数据。这个场景通常涉及到SQL查询的编写,利用Java来执行这些查询,并将结果展示给...

    delphi 系统开发 数据库模糊查询系统

    9. **多条件模糊查询**:如果需要根据多个字段进行模糊查询,可以使用`OR`或`AND`逻辑运算符组合多个`LIKE`条件,或者使用`IN`操作符匹配多个值。 10. **分页和排序**:在大量数据中,为了提高响应速度和用户体验,...

    参照工具数据库数据多列模糊查询

    1. **建立全文索引**:某些数据库系统如MySQL支持全文索引,能快速处理文本字段的模糊搜索。例如,为`姓名`和`地址`创建全文索引后,可以使用`MATCH AGAINST`进行查询。 2. **使用索引**:确保用于模糊查询的列上有...

    0.4 MySQL表查询之条件查询

    MySQL表查询之条件查询 MySQL表查询之条件查询是 MySQL 中的一种重要查询方式,用于筛选和提取数据库中的数据。条件查询的目的是为了从大量的数据中提取出所需的数据,以满足特定的操作或报告的需求。 1. 筛选...

    模糊查询所需组件

    在本资源中,我们将聚焦于模糊查询的实现及其所需的组件。 首先,模糊查询通常涉及到的关键组件包括: 1. **查询引擎**:这是执行模糊查询的核心部分,负责解析用户的输入,对比数据库中的记录,找出最匹配的结果...

    mysql中模糊查询的四种用法介绍

    本文将详细介绍四种常见的MySQL模糊查询用法,帮助你在处理数据库查询时更加灵活高效。 1. **百分号(%)**:百分号在模糊查询中代表任意数量的字符,包括零个字符。例如,`SELECT * FROM user WHERE u_name LIKE '...

    根据电话号,姓名模糊查询通讯录

    本教程将深入探讨如何实现"根据电话号,姓名模糊查询通讯录"这一功能。这个功能允许用户通过输入部分电话号码或姓名,就能找到相应的联系人信息,提高了用户体验。 首先,我们需要了解Android系统的通讯录访问机制...

Global site tag (gtag.js) - Google Analytics