MySQL instr()函数

转载自  MySQL instr()函数

MySQL INSTR函数简介

有时,您想要在字符串中查找子字符串或检查字符串中是否存在子字符串。在这种情况下,您可以使用字符串内置INSTR()函数。

INSTR()函数返回字符串中子字符串第一次出现的位置。如果在str中找不到子字符串,则INSTR()函数返回零(0)。

下面说明了INSTR函数的语法。

INSTR(str,substr);

SQL

INSTR函数接受两个参数:

  • str是要搜索的字符串。
  • substr是要搜索的子字符串。

INSTR()函数不区分大小写。这意味着如果通过小写,大写,标题大小写等,结果总是一样的。

如果希望INSTR函数在非二进制字符串上以区分大小写的方式执行搜索,则可以使用BINARY运算符将INSTR函数的参数从非二进制字符串转换为二进制字符串。

MySQL INSTR函数示例

以下语句返回MySQL INSTR字符串中的子字符串SQL的位置。

SELECT INSTR('MySQL INSTR', 'SQL');

SQL

执行上面查询语句,得到以下结果 -

mysql> SELECT INSTR('MySQL INSTR', 'SQL');
+-----------------------------+
| INSTR('MySQL INSTR', 'SQL') |
+-----------------------------+
|                           3 |
+-----------------------------+
1 row in set

SQL

以下语句返回相同的结果,因为INSTR函数不区分大小写。

SELECT INSTR('MySQL INSTR', 'sql');

SQL

执行上面查询语句,得到以下结果 -

mysql> SELECT INSTR('MySQL INSTR', 'sql');
+-----------------------------+
| INSTR('MySQL INSTR', 'sql') |
+-----------------------------+
|                           3 |
+-----------------------------+
1 row in set

SQL

要强制INSTR函数根据以区分大小写的方式进行搜索,请按如下所示使用BINARY运算符:

SELECT INSTR('MySQL INSTR', BINARY 'sql');

SQL

执行上面查询语句,得到以下结果 -

mysql> SELECT INSTR('MySQL INSTR', BINARY 'sql');
+------------------------------------+
| INSTR('MySQL INSTR', BINARY 'sql') |
+------------------------------------+
|                                  0 |
+------------------------------------+
1 row in set

SQL

结果是不同的,因为现在使用BINARY运算符,因为sqlSQL是不同的字符串。

INSTR函数与LIKE运算符

我们将使用示例数据库(yiibaidb)中的products表,其表结构如下 -

mysql> desc products;
+--------------------+---------------+------+-----+---------+------------------+
| Field              | Type          | Null | Key | Default | Extra            |
+--------------------+---------------+------+-----+---------+------------------+
| productCode        | varchar(15)   | NO   | PRI |         |                  |
| productName        | varchar(70)   | NO   | MUL | NULL    |                  |
| productLine        | varchar(50)   | NO   | MUL | NULL    |                  |
| productScale       | varchar(10)   | NO   |     | NULL    |                  |
| productVendor      | varchar(50)   | NO   |     | NULL    |                  |
| productDescription | text          | NO   |     | NULL    |                  |
| quantityInStock    | smallint(6)   | NO   |     | NULL    |                  |
| buyPrice           | decimal(10,2) | NO   |     | NULL    |                  |
| MSRP               | decimal(10,2) | NO   |     | NULL    |                  |
| stockValue         | double        | YES  |     | NULL    | STORED GENERATED |
+--------------------+---------------+------+-----+---------+------------------+
10 rows in set

SQL

假设要查找名称包含car关键字的产品,可以使用INSTR函数,如下所示:

SELECT productName
FROMproducts
WHEREINSTR(productname,'Car') > 0;

SQL

执行上面查询语句,得到以下结果 -

+----------------------------------------+
| productName                            |
+----------------------------------------+
| 1911 Ford Town Car                     |
| 1999 Indy 500 Monte Carlo SS           |
| 18th Century Vintage Horse Carriage    |
| 1917 Maxwell Touring Car               |
| 1950s Chicago Surface Lines Streetcar |
| 1962 City of Detroit Streetcar         |
+----------------------------------------+
6 rows in set

SQL

除了INSTR函数,可以使用LIKE运算符来匹配Car模式。

SELECT productname
FROMproducts
WHEREproductname LIKE '%Car%';

SQL

执行上面查询语句,得到以下结果 -

+----------------------------------------+
| productname                            |
+----------------------------------------+
| 1911 Ford Town Car                     |
| 1999 Indy 500 Monte Carlo SS           |
| 18th Century Vintage Horse Carriage    |
| 1917 Maxwell Touring Car               |
| 1950s Chicago Surface Lines Streetcar |
| 1962 City of Detroit Streetcar         |
+----------------------------------------+
6 rows in set

SQL

两个查询返回相同的结果。那么哪一个更快,INSTR还是LIKE操作符?

答案是它们是一样的,它们都区分大小写,并执行全表扫描。

让我们在productname列创建一个索引。

CREATE INDEX idx_products_name ON products(productname);

SQL

如果您使用具有前缀搜索的LIKE运算符,则在此索引列上,LIKE运算符的执行速度要比INSTR函数快。

请参阅以下查询语句 -

SELECT productname
FROMproducts
WHEREproductname LIKE '1900%';

SQL

执行上面查询语句,得到以下结果 -

+-------------------------+
| productname             |
+-------------------------+
| 1900s Vintage Bi-Plane  |
| 1900s Vintage Tri-Plane |
+-------------------------+
2 rows in set

SQL

您可以使用EXPLAIN语句检查它:

EXPLAIN SELECT productname
FROMproducts
WHEREproductname LIKE '1900%';

SQL

执行查询分析,得到以下结果 -

 

下面使用INSTR函数执行查询分析,以进行比较,参考以下语句 -

EXPLAIN SELECT productname
FROMproducts
WHEREinstr(productname,'1900');

SQL

执行查询分析,得到以下结果 -

 

即使productname列具有索引,INSTR函数也执行表扫描。 这是因为MySQL不能对INSTR函数的语义做任何假设,MySQL可以利用其对LIKE运算符语义的理解。

测试字符串中是否存在子字符串的最快方法是使用全文索引。 但是,需要正确配置和维护索引。

在本教程中,您已经学习了如何使用INSTR函数来查找字符串中子字符串第一次出现的位置。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/326478.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何给视频中插入视频,字幕,以及去掉前后广告

昨天白天接到了一个这样的需求,就是剪辑一段视频,给视频中加入插入一个剪短的介绍,然后把没有用的截取掉。 看起来很简单,确实,利用常用的视频剪辑软件就可以直接实现,但是事实并不是这样的,接…

ZKEACMS for .Net Core 深度解析

ZKEACMS 简介 ZKEACMS.Core 是基于 .Net Core MVC 开发的开源CMS。ZKEACMS可以让用户自由规划页面布局,使用可视化编辑设计“所见即所得”,直接在页面上进行拖放添加内容。 ZKEACMS使用插件式设计,模块分离,通过横向扩展来丰富CMS…

java design按钮_DesignJava 设计模式,讲述 的各种 方便在项目中进行 框架结构 Develop 238万源代码下载- www.pudn.com...

文件名称: DesignJava下载收藏√ [5 4 3 2 1 ]开发工具: Java文件大小: 1675 KB上传时间: 2013-11-21下载次数: 2提 供 者: 102426详细说明:JAVA设计模式,讲述java的各种设计模式,方便在项目中进行设计框架结构-JAVA design patterns, j…

MySQL count()函数

转载自 MySQL count()函数 MySQL COUNT()函数介绍 COUNT()函数返回表中的行数。 COUNT()函数允许您对表中符合特定条件的所有行进行计数。 COUNT()函数的语法如下 - COUNT(expression)SQL COUNT()函数的返回类型为BIGINT。 如果没有找到匹配的行,则COUNT()函…

剪辑视频、去掉爱剪辑前后广告、视频中添加黑幕简要教程

昨天白天接到了一个这样的需求,就是剪辑一段视频,给视频中加入插入一个剪短的介绍,然后把没有用的截取掉。看起来很简单,确实,利用常用的视频剪辑软件就可以直接实现,但是事实并不是这样的,接下…

弗洛伊德算法

思路分析 代码实现 package com.atguigu.floyd;import java.util.Arrays;public class FloydAlgorithm {public static void main(String[] args) {//测试看看图是否创建成功char[] vertex{A,B,C,D,E,F,G};//创建邻接矩阵int[][] matrixnew int[vertex.length][vertex.length]…

Productivity Power Tools,对于Visual Studio 2017的15个扩展

在Visual Studio 2017正式发布期间,微软公司更新并发布了Productivity Power Tools的扩展版本。Productivity Power Tools的这个版本包括了针对VS 2017的15处扩展。 新版本Productivity Power Tools的优点之一是它允许微软监测哪些组件是开发者最频繁使用的&#xf…

java 读取svg元素_svg动态添加元素

动态添加元素x坐标值y坐标值文本内容动态添加元素var svgDoc null;var time null;// 动态添加元素var addElement function(x, y, nodeText) {// 添加圆形var c svgDoc.createElementNS(http://www.w3.org/2000/svg, circle);c.setAttribute(cx, x);c.setAttribute(cy, y);…

常用数据库复习资料

mast:数据库控制SQL Server的所有方面。这个数据库中包括所有的配置信息、用户登录信息、当前正在服务器中运行的过程的信息。model:数据库是建立所有用户数据库时的模板。当你建立一个新数据库时,SQL Server会把model数据库中的所有对象建立一份拷贝并移…

Java:comp/env/讲解与JNDI

转载自 "Java:comp/env/"讲解与JNDI 我们在使用JNDI调用某个对象时,会有下述两种方式 context.lookup(“java:comp/env/XXX”) context.lookup(“XXX”) context.lookup(“java:comp/env/XXX”)只能用在J2EE环境,如果你自己写一个main函数…

利用 Azure Functions 实现无服务器体系结构

从工具到机器再到计算机,我们一直在寻找能够自动执行重复工作并让我们所处理的上下文规范化的方法,以便我们可以将重心放在做出高价值的专业化贡献上,从而完成任务并解决问题。 与此同时,很显然,随着 IT 产业的不断发展…

2020蓝桥杯省赛---java---C---3( 跑步训练)

题目描述 代码实现 方式一 方式二 package com.atguigu.lanqiao;public class Main {public static void main(String[] args) {int target10000;int count0;boolean flagtrue;//判断此次是否需要跑步while (true){//如果小于600体力并且需要跑步,证明这一分钟跑…

python 找色点击_Python实现按键精灵(二)-找图找色

一、实现功能判断在指定坐标范围内,是否存在相似度大于n的图片,并返回坐标。二、基本思路A你需要寻找的图片B截取当前页面中指定范围的图片利用opencv 判断A在B中的位置,在该位置截取与A图同大小的图片C对比图片C与图片A的相似度三、实现的代…

Numeral.js数字格式化

翻译自 Numeral.js 用它 在浏览器中 <script src"numeral.min.js"></script> 或者引用从cdnjs.com <script src"http://cdnjs.cloudflare.com/ajax/libs/numeral.js/2.0.6/numeral.min.js"></script> 在Node.js中 npm inst…

sqlserver中常用的几个存储过程

sqlserver中的存储过程&#xff0c;何为存储过程呢&#xff1f; 存储过程&#xff08;Stored Procedure&#xff09;是在大型数据库系统中&#xff0c;一组为了完成特定功能的SQL 语句集&#xff0c;存储在数据库中&#xff0c;经过第一次编译后再次调用不需要再次编译&#x…

java枚举类定义性别_Java 枚举类和自定义枚举类和enum声明及实现接口的操作

1.枚举类注&#xff1a;JDK1.5之前需要自定义枚举类JDK 1.5 新增的 enum 关键字用于定义枚举类若枚举只有一个成员, 则可以作为一种单例模式的实现方式1.枚举类的属性1、枚举类对象的属性不应允许被改动, 所以应该使用 private final 修饰2、枚举类的使用 private final 修饰的…

2020蓝桥杯省赛---java---B---4( 合并检测)

题目描述 思路分析 假设A国有n个人&#xff0c;感染者有n/100 每k个人一组&#xff0c;共n/k组&#xff0c;共用n/k瓶试剂 按照最坏的情况&#xff0c;每多出一个感染者就多用k瓶试剂&#xff0c; 因此共用n/k(n/100)*k瓶试剂 n是定值&#xff0c;所以求(1/kk/100)最小 由于ab…

visual studio 2017发布dotnet core到docker

docker的好处不用多说&#xff0c;有不了解的可移步《docker入门》&#xff0c;作为一个.net方面的老鸟也想早点搭上docker末班车&#xff0c;减少布署中的各种坑。以下我是在Visual Studio 2017正式版发布后&#xff08;其实VS2015也是可以的&#xff09;&#xff0c;完全跑起…

URLSearchParams 接口

转载自 URLSearchParams 接口 URLSearchParams 接口定义了很多个用来处理 URL 参数串的方法。 基本使用方法如下 var paramsString "qURLUtils.searchParams&topicapi" // location.search.slice(1) var searchParams new URLSearchParams(paramsString);s…

JDK环境变量配置

1.变量名&#xff1a; JAVA_HOME 变量值&#xff1a;&#xff08;变量值填写你的jdk的安装目录&#xff0c;例如本人是 E:\Java\jdk1.8.0&#xff09;2.变量名&#xff1a; Path 变量值&#xff1a; ;%JAVA_HOME%\bin;%JAVA_HOME%\jre\bin;3.变量名&#xff1a; CLASSPATH 变量…