php如何模糊查询字符串? - 技术问答

发布网友 发布时间:2022-04-06 04:26

我来回答

8个回答

懂视网 时间:2022-04-06 08:47

php实现模糊查询的方法:1、使用SQL匹配模式,操作符就要使用LIKE或NOT LIKE,匹配时,不区分大小写;2、使用正则表达式匹配模式,其正则表达式出现在匹配字段的任意位置。

【相关学习推荐:php编程(视频)】

php实现模糊查询的方法:

方法1:SQL匹配模式

1.使用sql匹配模式,不能使用操作符=!=,而是使用操作符LIKE或NOT LIKE;

2.使用sql匹配模式,MYSQL提供了2种通配符。

  • %表示任意数量的任意字符(其中包括0个)

  • _表示任意单个字符

  • 3.使用sql匹配模式,如果匹配格式中不包含以上2种通配符中的任意一个,其查询的效果等同于=或!=

    4.使用sql匹配模式,匹配时,不区分大小写

    #查询用户名以某个字符开头的用户
    #查询用户名以字符'l'开头的用户: l%
    SELECT * FROM user WHERE username LIKE 'l%';
    #查询用户名以某个字符结尾的用户
    #查询用户名以字符'e'结尾的用户:e%
    SELECT * FROM user WHERE username LIKE 'e%';
    #查询用户名包含某个字符的用户
    #查询用户名包含字符'o'的用户:%o%
    SELECT * FROM user WHERE username LIKE '%o%';
    #查询包含三个字符的用户
    SELECT * FROM user WHERE username LIKE '___';
    #查询用户名第二个字符为o的用户:_o%
    SELECT * FROM user WHERE username LIKE '_o%';

    方法2:正则表达式匹配模式

    通配符(正则表达式)

    .匹配任意的单个字符

    *匹配0个或多个在它前面的字符

    x*表示匹配任何数量的x字符

  • [..]匹配中括号中的任意字符

  • [abc]匹配字符ab或c

  • [a-z]匹配任意字母

  • [0-9]匹配任意数字

  • [0-9]*匹配任意数量的任何数字

  • [a-z]*匹配任何数量的字母

  • ^表示以某个字符或字符串开始

    ^a 表示以字母a开头

    $表示以某个字符或字符串结尾

    s$表示以字母s结尾

    使用正则表达式匹配模式使用的操作符是:

    REGEXP NOT REGEXP(RLIKE 或 NOT RLIKE)

    注意:正则表达式匹配模式,其正则表达式出现在匹配字段的任意位置,

    其模式就算匹配了,不必在两侧放一个通配符来使得其匹配;

    如果仅用通配符 . 来匹配,假设N个,那么其匹配模式表示,大于等于N个;

    怎么理解上面这句话呢?

    就是说

    ... 匹配大于等于3个字符的数据

    .... 匹配大于等于4个字符的数据

    #查询用户名以字符 l开头的用户:^l;

    #正则表达式写法

    SELECT * FROM user WHERE username REGEXP '^l';
    #sql匹配模式写法:
    SELECT * FROM user WHERE username LIKE 'l%';
    #查询用户名正好是三个字符的用户:^...$;
    #sql匹配模式写法:
    SELECT * FROM user WHERE username LIKE '___';
    #正则表达式写法
    SELECT * FROM user WHERE username REGEXP '^...$';

    热心网友 时间:2022-04-06 05:55

    可以用PHP里的strpos函数,这个函数可以实现你的要求,如:$str_add = \'中国人民银行\';
    function fun($str1,$str2)
    if(strpos($str1,$str2)!==-1) {
    echo "true";

    }
    fun($str_add1,'银行');
    这个函数就实现了你想要的功能了

    热心网友 时间:2022-04-06 07:13

    唉,自己搞定了。function checkstr($str){ $needle = \"a\";//判断是否包含a这个字符 $tmparray = explode($needle,$str); if(count($tmparray)>1){ return true; } else{ return false; } } 到技术吧网站查看回答详情>>

    热心网友 时间:2022-04-06 08:48

    [pre=brush:php;toolbar:false;]function fun($a, $b) {
    if(strpos($a, $b) !== -1) {
    return true;
    }
    else {
    return false;
    }
    }[/pre]

    热心网友 时间:2022-04-06 10:39

    [pre=brush:php;toolbar:false;]if($item['isBest'] != 1 || empty($item['ext_pack']['ent_special_type'])) continue;[/pre]

    热心网友 时间:2022-04-06 12:47

    [pre=brush:delphi;toolbar:false;]program p1;
    var a,b,sum:integer;
    begin
    write('Please input A:');
    readln(a);
    write('Please input B:');
    readln(b);
    sum:=a+b;
    writeln('sum=',sum);
    readln
    end.[/pre]

    热心网友 时间:2022-04-06 15:12

    [pre=brush:php;toolbar:false;]echo "Hello, World"[/pre]

    热心网友 时间:2022-04-06 17:53

    实用like查询

    声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com