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)同义词。

  • 相关阅读:
    类特性:多态
    类特性:继承
    类,对象入门
    cf round599 CDE
    cf round#598 CDEF
    高精度小数BigDecimal+二分——java
    点分治
    java——IO(普通文件,二进制文件,压缩文件 )
    JCF——Map
    JCF——set
  • 原文地址:https://www.cnblogs.com/duanxz/p/4505120.html
Copyright © 2011-2022 走看看