如何用MYSQL模糊查询···

例如一个人的名字叫 张学友,输入“学友”或者“张学”或者其中一个字都能显示其相关的名字出来,最近毕业论文做网站要求这样,可是我的SQL学的很烂·····大虾们帮帮忙····

SQL模糊查询的语法为
“SELECT column FROM table WHERE column LIKE ';pattern';”。

SQL提供了四种匹配模式:
1. % 表示任意0个或多个字符。如下语句:
SELECT * FROM user WHERE name LIKE ';%三%';
将会把name为“张三”,“三脚猫”,“唐三藏”等等有“三”的全找出来;

2. _ 表示任意单个字符。语句:
SELECT * FROM user WHERE name LIKE ';_三_';
只找出“唐三藏”这样name为三个字且中间一个字是“三”的;
SELECT * FROM user WHERE name LIKE ';三__';
只找出“三脚猫”这样name为三个字且第一个字是“三”的;

3. [ ] 表示括号内所列字符中的一个(类似与正则表达式)。语句:
SELECT * FROM user WHERE name LIKE ';[张李王]三';
将找出“张三”、“李三”、“王三”(而不是“张李王三”);

如 [ ] 内有一系列字符(01234、abcde之类的)则可略写为“0-4”、“a-e”
SELECT * FROM user WHERE name LIKE ';老[1-9]';
将找出“老1”、“老2”、……、“老9”;
如要找“-”字符请将其放在首位:';张三[-1-9]';

4. [^ ] 表示不在括号所列之内的单个字符。语句:
SELECT * FROM user WHERE name LIKE ';[^张李王]三';
将找出不姓“张”、“李”、“王”的“赵三”、“孙三”等;
SELECT * FROM user WHERE name LIKE ';老[^1-4]';
将排除“老1”到“老4”寻找“老5”、“老6”、……、“老9”。

!最后是重点!
由于通配符的缘故,导致我们查询特殊字符“%”、“_”、“[”、“';”的语句无法正常实现,而把特殊字符用“[ ]”括起便可正常查询。据此我们写出以下函数:

function sqlencode(str)
str=replace(str,"';","';';")
str=replace(str,"[","[[]") ';此句一定要在最先
str=replace(str,"_","[_]")
str=replace(str,"%","[%]")
sqlencode=str
end function
温馨提示:内容为网友见解,仅供参考
第1个回答  2020-12-03

本视频详细讲解了MySQL的相关知识,包括MySQL概述,MySQL应用环境,MySQL系统特性,MySQL初学基础,MySQL管理工具,如何安装MySQL及MySQL新特性,通过观看本套Java视频教程就可掌握MySQL全套知识

第2个回答  2013-06-20
如果是通过姓名查找呢,我建议你还是把所有姓都定义好在查询吧(可以通过拼音索引增加软件友好度),这样查询的效率会好很多,总比每次都要把姓名从数据库里拿出来再抽象成模糊查询字段
再查询要快吧。
如果真是可以自己抽象出来所有符合的模糊对象的话,我看快赶上人工智能了,计算量不小。现阶段应该还用不到。用到了,我们也做不出来。
不知道对你有用吗,第二次回答问题。
O(∩_∩)O哈哈~

如何用mysql模糊查询?
一、使用LIKE关键字 在MySQL中,LIKE关键字用于在WHERE子句中搜索列中的指定模式。该关键字与通配符一起使用,以执行模糊匹配。二、通配符的使用 1. %:代表零个、一个或多个字符。例如,%apple%将匹配包含“apple”的所有字符串,无论其前后是否有其他字符。2. _:代表一个单一的字符。例如,_apple...

MySQL中的模糊查询不完全匹配的使用方法详解mysql不完全匹配
需要注意的是,% 和 _ 必须跟在关键字的前后或中间,不能放在关键字的两端,不然会匹配失败。二、匹配规则 在进行模糊查询时,MySQL是区分大小写的,也就是说,查询关键字的大小写必须与数据库中的记录中的相应部分大小写完全一致。假设有一个表t_User记录了若干用户的信息:| id | name | age...

MySQL模糊查询如何使用不完全匹配mysql不完全匹配
SELECT * FROM tablename WHERE fieldname LIKE ‘ABC%DEF’;这个查询表示查找以ABC开头DEF结尾的名字, %表示任意多个字符。比如我们要查询名字以‘ABC’开头,以‘DEF’结尾的员工信息, 可以用以下语句:SELECT * FROM employee WHERE name LIKE ‘ABC%DEF’;综上,SQL的模糊...

MySQL的下划线模糊查询原理和方法详解mysql下划线模糊查询
下划线模糊查询是指在查询数据时,使用下划线符号(_)代替一个任意字符,以达到模糊匹配的目的。下划线符号只能代替一个字符,不能代替多个字符。例如,当需要查询以ab开头,c结尾的4位字符串时,可以使用下划线模糊查询:ab_c。二、下划线模糊查询的应用 下划线模糊查询通常用于以下场合:1.查询所有满足特定...

如何用MYSQL模糊查询···
SQL模糊查询的语法为 “SELECT column FROM table WHERE column LIKE ';pattern';”。SQL提供了四种匹配模式:1. % 表示任意0个或多个字符。如下语句:SELECT * FROM user WHERE name LIKE ';%三%';将会把name为“张三”,“三脚猫”,“唐三藏”等等有“三”的全找出来;2. _ 表示任意单个...

MySQL三表模糊查询实现方法mysql三表模糊查询
本文将基于MySQL数据库,介绍如何实现三表联查,并且完成多个字段的模糊查询。准备工作 在开始之前,需要准备好以下环境:– 安装MySQL数据库。– 创建三张表,并插入数据。我们假设有三张表:users, departments和roles。它们的表结构和数据如下:CREATE TABLE users (id INT(11) PRIMARY KEY...

MySQL模糊查询用法大全(正则、通配符、内置函数等)
MySQL模糊查询的实用技巧全览,涵盖正则表达式、通配符和内置函数等方法。常规情况下,我们常用LIKE操作符配合%通配符进行模糊搜索,如`SELECT * from table where username like '%陈哈哈%' and hobby like '%牛逼%'`。实际上,MySQL模糊匹配的手段远不止于此。首先,通配符的使用十分灵活。%代表任意...

如何用MYSQL模糊查询?
如果 WHERE 子句的查询条件里使用比较操作符 LIKE 和 REGEXP,MySQL 只有在搜索模板的第一个字符不是通配符的情况下才能使用索引。比如说,如果查询条件是 LIKE 'abc%‘,MySQL 将使用索引;如果查询条件是 LIKE '%abc’,MySQL 将不使用索引。在 ORDER BY 操作中,MySQL 只有在排序条件不是一个查询...

MySQL数据库中的两张表如何进行模糊匹配mysql两张表模糊匹配
在MySQL中,可以使用LIKE操作符进行模糊查询。LIKE操作符可以匹配任意字符串,包括数字和特殊符号。使用LIKE操作符进行模糊匹配时,需要注意使用通配符,即%和_。%表示任意一组字符(包括空格),_表示任意一个字符(不包括空格)。例如,’%张%’表示以张为姓氏的所有学生,’%张大__%...

mysql模糊查询怎么查多个字段
1.返回值:由全体出入参数合并在一起而得到的字符串。只要输入的参数中有NULL值,就返回NULL。CONCAT允许只有一个输入参数的情况。因此,MySQL单表多字段模糊查询可以通过下面这个SQL查询实现 SELECT * FROM `magazine` WHERE CONCAT(`title`,`tag`,`description`) LIKE ‘%关键字%’2.如果这三个字段...

相似回答