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

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

 
  1. mysql> SELECT INSTR('MySQL INSTR', 'SQL');

  2. +-----------------------------+

  3. | INSTR('MySQL INSTR', 'SQL') |

  4. +-----------------------------+

  5. | 3 |

  6. +-----------------------------+

  7. 1 row in set

SQL

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

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

SQL

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

 
  1. mysql> SELECT INSTR('MySQL INSTR', 'sql');

  2. +-----------------------------+

  3. | INSTR('MySQL INSTR', 'sql') |

  4. +-----------------------------+

  5. | 3 |

  6. +-----------------------------+

  7. 1 row in set

SQL

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

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

SQL

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

 
  1. mysql> SELECT INSTR('MySQL INSTR', BINARY 'sql');

  2. +------------------------------------+

  3. | INSTR('MySQL INSTR', BINARY 'sql') |

  4. +------------------------------------+

  5. | 0 |

  6. +------------------------------------+

  7. 1 row in set

SQL

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

INSTR函数与LIKE运算符

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

 
  1. mysql> desc products;

  2. +--------------------+---------------+------+-----+---------+------------------+

  3. | Field | Type | Null | Key | Default | Extra |

  4. +--------------------+---------------+------+-----+---------+------------------+

  5. | productCode | varchar(15) | NO | PRI | | |

  6. | productName | varchar(70) | NO | MUL | NULL | |

  7. | productLine | varchar(50) | NO | MUL | NULL | |

  8. | productScale | varchar(10) | NO | | NULL | |

  9. | productVendor | varchar(50) | NO | | NULL | |

  10. | productDescription | text | NO | | NULL | |

  11. | quantityInStock | smallint(6) | NO | | NULL | |

  12. | buyPrice | decimal(10,2) | NO | | NULL | |

  13. | MSRP | decimal(10,2) | NO | | NULL | |

  14. | stockValue | double | YES | | NULL | STORED GENERATED |

  15. +--------------------+---------------+------+-----+---------+------------------+

  16. 10 rows in set

SQL

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

 
  1. SELECT

  2. productName

  3. FROM

  4. products

  5. WHERE

  6. INSTR(productname,'Car') > 0;

SQL

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

 
  1. +----------------------------------------+

  2. | productName |

  3. +----------------------------------------+

  4. | 1911 Ford Town Car |

  5. | 1999 Indy 500 Monte Carlo SS |

  6. | 18th Century Vintage Horse Carriage |

  7. | 1917 Maxwell Touring Car |

  8. | 1950s Chicago Surface Lines Streetcar |

  9. | 1962 City of Detroit Streetcar |

  10. +----------------------------------------+

  11. 6 rows in set

SQL

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

 
  1. SELECT

  2. productname

  3. FROM

  4. products

  5. WHERE

  6. productname LIKE '%Car%';

SQL

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

 
  1. +----------------------------------------+

  2. | productname |

  3. +----------------------------------------+

  4. | 1911 Ford Town Car |

  5. | 1999 Indy 500 Monte Carlo SS |

  6. | 18th Century Vintage Horse Carriage |

  7. | 1917 Maxwell Touring Car |

  8. | 1950s Chicago Surface Lines Streetcar |

  9. | 1962 City of Detroit Streetcar |

  10. +----------------------------------------+

  11. 6 rows in set

SQL

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

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

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

CREATE INDEX idx_products_name ON products(productname);

SQL

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

请参阅以下查询语句 -

 
  1. SELECT

  2. productname

  3. FROM

  4. products

  5. WHERE

  6. productname LIKE '1900%';

SQL

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

 
  1. +-------------------------+

  2. | productname |

  3. +-------------------------+

  4. | 1900s Vintage Bi-Plane |

  5. | 1900s Vintage Tri-Plane |

  6. +-------------------------+

  7. 2 rows in set

SQL

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

 
  1. EXPLAIN SELECT

  2. productname

  3. FROM

  4. products

  5. WHERE

  6. productname LIKE '1900%';

SQL

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

 

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

 
  1. EXPLAIN SELECT

  2. productname

  3. FROM

  4. products

  5. WHERE

  6. instr(productname,'1900');

SQL

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

 

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

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

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

转载:https://blog.csdn.net/moakun/article/details/81876559

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值