zoukankan      html  css  js  c++  java
  • Mysql函数INSTR、LOCATE、POSITION VS LIKE

    Mysql 大家都会用这样的語法:

    SELECT `column` FROM `table` where `condition` like `%keyword%’

    事实上,可以使用 locate 和 instr 这两个函数来代替

    SELECT `column` from `table` where locate(‘keyword’, `condition`)>0
    或是 locate 的別名 position
    SELECT `column` from `table` where position(‘keyword’ IN `condition`)

    或是
    SELECT `column` from `table` where instr(`condition`, ‘keyword’ )>0

    locate、position 和 instr 的差別只是参数的位置不同,同时locate 多一个请始位置的参数外,两者是一样的。

    速度上这三个比用 like 稍快了一點。

    另付三个函数的说明:

    • INSTR(str,substr)

    返回字符串 str 中子字符串的第一个出现位置。这和LOCATE()的双参数形式相同,只是参数的顺序被颠倒。

    mysql> SELECT INSTR(‘foobarbar’, ‘bar’);

    -> 4

    mysql> SELECT INSTR(‘xbar’, ‘foobar’);

    -> 0

    这个函数支持多字节字元,并且只有当至少有一个参数是二进制字符串时区分大小写。

    • LOCATE(substr,str) , LOCATE(substr,str,pos)

    第一个语法返回字符串 str中子字符串substr的第一个出现位置。第二个语法返回字符串str中子字符串substr的第一个出现位置, 起始位置在pos。如若substr 不在str中,则返回值为0。

    mysql> SELECT LOCATE(‘bar’, ‘foobarbar’);

    -> 4

    mysql> SELECT LOCATE(‘xbar’, ‘foobar’);

    -> 0

    mysql> SELECT LOCATE(‘bar’, ‘foobarbar’,5);

    -> 7

    这个函数支持多字节字元,并且只有当至少有一个参数是二进制字符串时区分大小写。

    • POSITION(substr IN str)

    POSITION(substr IN str)是 LOCATE(substr,str)同义词。

  • 相关阅读:
    AcWing 157. 树形地铁系统 (hash判断树同构)打卡
    AcWing 156. 矩阵 (哈希二维转一维查询)打卡
    AcWing 144. 最长异或值路径 01字典树打卡
    AcWing 143. 最大异或对 01字典树打卡
    AcWing 142. 前缀统计 字典树打卡
    AcWing 139. 回文子串的最大长度 hash打卡
    AcWing 138. 兔子与兔子 hash打卡
    常用C库函数功能及用法
    编程实现C库函数
    C语言面试题5
  • 原文地址:https://www.cnblogs.com/duanxz/p/4505120.html
Copyright © 2011-2022 走看看