在进行数据库查询时,有完整查询和模糊查询之分。

一般模糊语句如下:

SELECT 字段 FROM 表 WHERE 某字段 Like 条件

其中关于条件,SQL提供了四种匹配模式:

1,%:表示任意0个或多个字符。可匹配任意类型和长度的字符,有些情况下若是中文,请使用两个百分号(%%)表示。

比如 SELECT * FROM [user] WHERE u_name LIKE '%三%'

将会把u_name为"张三","张猫三"、"三脚猫","唐三藏"等等有"三"的记录全找出来。

另外,如果需要找出u_name中既有"三"又有"猫"的记录,请使用and条件

SELECT * FROM [user] WHERE u_name LIKE '%三%' AND u_name LIKE '%猫%'

若使用 SELECT * FROM [user] WHERE u_name LIKE '%三%猫%'

虽然能搜索出"三脚猫",但不能搜索出符合条件的"张猫三"。

2,_: 表示任意单个字符。匹配单个任意字符,它常用来限制表达式的字符长度语句:

比如 SELECT * FROM [user] WHERE u_name LIKE '_三_'

只找出"唐三藏"这样u_name为三个字且中间一个字是"三"的;

再比如 SELECT * FROM [user] WHERE u_name LIKE '三__';

只找出"三脚猫"这样name为三个字且第一个字是"三"的;

3,[ ]:表示括号内所列字符中的一个(类似正则表达式)。指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。

比如 SELECT * FROM [user] WHERE u_name LIKE '[张李王]三'

将找出"张三"、"李三"、"王三"(而不是"张李王三");

如 [ ] 内有一系列字符(01234、abcde之类的)则可略写为"0-4"、"a-e"

SELECT * FROM [user] WHERE u_name LIKE '老[1-9]'

将找出"老1"、"老2"、……、"老9";

4,[^ ] :表示不在括号所列之内的单个字符。其取值和 [] 相同,但它要求所匹配对象为指定字符以外的任一个字符。

比如 SELECT * FROM [user] WHERE u_name LIKE '[^张李王]三'

将找出不姓"张"、"李"、"王"的"赵三"、"孙三"等;

SELECT * FROM [user] WHERE u_name LIKE '老[^1-4]';

将排除"老1"到"老4",寻找"老5"、"老6"、……

5,查询内容包含通配符时

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

function sqlencode(str)

str=replace(str,"[","[[]") '此句一定要在最前

str=replace(str,"_","[_]")

str=replace(str,"%","[%]")

sqlencode=str

end function

在查询前将待查字符串先经该函数处理即可。

mysql数据库模糊查询简介相关推荐

  1. MySQL 数据库 模糊查询和聚合函数

    模糊查询: like 运算符 通配符:%--代表0-n个任意字符 - --代表单个任意字符 注意:只有char.varchar.text类型才能使用 例子: select * from student ...

  2. MySQL数据库模糊查询什么时候可以使用到索引

    正常情况下,当使用模糊查询字段,例如like "%hh",%开头的查询时是没办法使用索引的,但是使用like "kk%" 模糊字段在后面的也是可以使用索引的. ...

  3. 关于mysql数据库模糊查询的潜在问题

    初学者在学习的时候经常会写下面的模糊查询语句: SELECT * FROM student WHERE Sname like '%蔡徐坤%' 有两方面的问题,第一,我们从结果分析入手: 我们想看到的是 ...

  4. vc mysql 查询_VC++数据库模糊查询及精确查询示例代码分享

    VC++数据库模糊查询及精确查询示例代码分享是小编为大家带来的一个VC++电话簿程序中的模糊查询例子源代码,结合数据库,可以学习研究下简单一点的模糊查询和精确查询,希望能对大家有帮助,,赶紧来详细了解 ...

  5. mysql查询单个员工信息_PHP+MySQL实现模糊查询员工信息功能示例

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

  6. MySQL中删除数据库的基本语法格式为_《MySQL数据库》SQL简介、语法格式

    原标题:<MySQL数据库>SQL简介.语法格式 一.SQL的简介 结构化查询语言(Structured Query Language),简称SQL.它是专门用来访问数据库的标准编程语言. ...

  7. mysql模糊查询单词_你知道什么是 MySQL 的模糊查询?

    原标题:你知道什么是 MySQL 的模糊查询? 作者 | luanhz 责编 | 郭芮 本文对MySQL中几种常用的模糊搜索方式进行了介绍,包括LIKE通配符.RegExp正则匹配.内置字符串函数以及 ...

  8. MySQL数据库select查询命令大全

    MySQL数据库select查询命令大全 --数据库操作前的准备 -- 创建数据库 -- create database python_test_1 charset=utf8; -- 使用数据库 -- ...

  9. Mysql数据库常用查询方法及演示(where条件查询、分页、排序等)

    Mysql数据库常用查询方法及演示 where条件查询的介绍 使用where条件查询可以对表中的数据进行筛选,条件成立的记录会出现在结果集中. where语句支持的运算符: 比较运算符 逻辑运算符 模 ...

最新文章

  1. javascript 事件对象
  2. Saber2016安装包和安装详细安装步骤
  3. conductor任务域
  4. 【目标检测】cvpr21_Sparse R-CNN: End-to-End Object Detection with Learnable Proposals
  5. awk用法小结(作者总结)
  6. spring mvc controller json数据
  7. Linux rescue救援(光盘修复)模式详解
  8. 什么是IP地址?由哪几部分构成?IP地址分为几类?
  9. 运维定位服务故障时,前5分钟都在忙啥?
  10. linux nvme驱动编译,Linux nvme驱动初探
  11. 遗传算法实践详解(deap框架初体验)
  12. 5类6类7类网线对比_超五类、六类、七类网线竟然有这么多不同之处
  13. 文件服务器文件夹卷影副本,配置共享文件夹的卷影副本功能 - Windows Server | Microsoft Docs...
  14. 第4章数据库的查询、视图和游标
  15. sql查询语句中分组添加小计,GROUPING的使用
  16. 类似Confluence的软件有哪些
  17. tomcat控制台不打印异常问题
  18. 2021年两次系统集成项目管理工程师真题各章节占分比对比
  19. linux hudson svn,Hudson Maven SVN快速搭建持续集成环境
  20. html制作文字图片的软件,自己做文字图片的软件哪个好用

热门文章

  1. es6中的promise解读
  2. 【推荐】2016年不得不读的九本好书
  3. 2015-11-16
  4. string 类的常用方法 substring indexof length
  5. 【Linux】安装前的准备-----安装纯净版的虚拟机的步骤
  6. java.util.concurrent.*下的常见类你了解多少?
  7. stats | 线性回归(二)——模型假设和模型估计
  8. Hi3559av100安装linux,海思hi3559AV100开发板参数规格介绍
  9. sqlserver php用户登陆页,SQLServer限制IP,限制用户,限制SSMS登录
  10. 线性回归(三)---岭回归