查询功能在日常开发中经常会使用到,今天我们php中文网就带大家梳理一下查询功能实现方法,以及简单介绍下在thinkphp中如何使用查询功能。

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%';

通配符(正则表达式)

.匹配任意的单个字符

*匹配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 '^...$';

thinkphp like模糊查询

目前使用thinkphp框架进行项目开发的人越来越多了,由于其封装性较好,导致了很多纯PHP开发的部分不易上手,本文实例即以like模糊查询为例对此加以说明。

这里主要通过举例来说明用法:

ThinkPHP可以支持直接使用字符串作为查询条件,但是大多数情况推荐使用索引数组或者对象来作为查询条件,因为会更加安全。

一、使用字符串作为查询条件

这是最传统的方式,但是安全性不高,

例如:$User = M("User"); // 实例化User对象

$User->where('type=1 AND status=1')->select();

最后生成的SQL语句是SELECT * FROM think_user WHERE type=1 AND status=1

如果进行多字段查询,那么字段之间的默认逻辑关系是 逻辑与 AND,但是用下面的规则可以更改默认的逻辑判断,通过使用 _logic 定义查询逻辑:$User = M("User"); // 实例化User对象

$condition['name'] = 'thinkphp';

$condition['account'] = 'thinkphp';

$condition['_logic'] = 'OR';

// 把查询条件传入查询方法

$User->where($condition)->select();

最后生成的SQL语句是SELECT * FROM think_user WHERE `name`='thinkphp' OR `account`='thinkphp'

二、数组方式作为查询条件

讲了这么多了like查询怎么实现呢,下面看$userForm=M('user');

$where['name']=array('like','php%');

$userForm->where($where)->select();

这里的like查询即为:name like 'php%'

查询语句:$where['name']=array('like',array('%php%','%.com'),'OR');