0

0

ThinkPHP--SQL 查询语句

php中文网

php中文网

发布时间:2016-08-08 09:31:20

|

1512人浏览过

|

来源于php中文网

原创

一.查询方式

ThinkPHP 提供了三种基本的查询方式:字符串条件查询、索引数组条件查询和对象条
件查询。在大多数情况下,推荐使用索引数组和对象方式作为查询条件,因为会更加安全
1.使用字符串作为条件查询
//字符串作为条件查询
$user = M('User');
var_dump($user->where('id=1 AND user="蜡笔小新"')->select());
//最终生成的SQL 语句
SELECT * FROM `think_user` WHERE ( id=1 AND user="蜡笔小新" )
PS:where 查询方法里面只要包含条件即可,多个条件加上AND 等连接符即可。我们会
在SQL 连贯操作详细学习。
2.使用索引数组作为查询条件
//索引数组作为条件查询
$user = M('User');
$condition['id'] = 1;
$condition['user'] = '蜡笔小新';
var_dump($user->where($condition)->select());
//最终生成的SQL 语句
SELECT * FROM `think_user` WHERE ( `id` = 1 ) AND ( `user` = '蜡笔小
新' )
PS:索引数组查询的默认逻辑关系是AND,如果想改变为OR,可以使用_logic 定义查
询逻辑。
基于上面的代码增加如下一行:
$condition['_logic'] = 'OR'; //将默认AND 改成OR
3.使用对象方式来查询
//对象作为条件查询
$user = M('User');
$condition = new \stdClass();
$condition->id = 1;
$condition->user = '蜡笔小新';
var_dump($user->where($condition)->select());
//最终生成的SQL 语句
SELECT * FROM `think_user` WHERE ( `id` = 1 ) AND ( `user` = '蜡笔小
新' )
PS:stdClass 类是PHP 内置的类,可以理解为一个空类,在这里可以理解为把条件的
字段作为成员保存到stdClass 类里。而这里的'\'是将命名空间设置为根目录,否则会导
致当前目录找不到此类。使用对象和数组查询,效果是一样的,可以互换。在大多数情况下,
ThinkPHP 推荐使用数组形式更加高效。

二.表达式查询

对于那些要实现模糊判断的查询,比如大于、等于、小于之类的SQL查询,可以使用表
达式查询方式。
查询表达式格式:$map['字段名'] = array('表达式','查询条件');
表达式查询表
表达式含义
EQ 等于(=)
NEQ 不等于()
GT 大于(>)
EGT 大于等于(>=)
LT 小于(ELT 小于等于([NOT]LIKE 模糊查询
[NOT] BETWEEN (不在)区间查询
[NOT] IN (不在)IN查询
EXP 表达式查询,支持SQL语法
PS:表达式不区分大小写。
//EQ:等于(=)
$map['id'] = array('eq', 1); //where 为id=1
//NEQ:不等于()
$map['id'] = array('neq', 1); //where 为id1
//GT:大于(>)
$map['id'] = array('gt', 1); //where 为id>1
//EGT:大于等于(>=)
$map['id'] = array('egt', 1); //where 为id>=1
//LT:小于($map['id'] = array('lt', 1); //where 为id//ELT:小于等于($map['id'] = array('elt', 1); //where 为id//[NOT]LIKE:模糊查询
$map['user'] = array('like', '%小%'); //where 为like %小%
//[NOT]LIKE:模糊查询
$map['user'] = array('notlike', '%小%'); //where 为not like %小%
//[NOT]LIKE:模糊查询的数组方式
$map['user'] = array('like', array('%小%', '%蜡%'), 'AND');
//生成的SQL
SELECT * FROM `think_user` WHERE ( (`user` LIKE '%小%' AND `user`
LIKE '%蜡%') )
//[NOT] BETWEEN:区间查询
$map['id'] = array('between','1,3');
//where 为`id` BETWEEN '1' AND '2'
//同上等效
$map['id'] = array('between',array('1','3'));
//[NOT] BETWEEN:区间查询
$map['id'] = array('not between','1,3');
//where 为`id` NOT BETWEEN '1' AND '2'
//[NOT] IN:区间查询
$map['id'] = array('in','1,2,4');
//where 为`id` IN ('1','2','4')
//[NOT] IN:区间查询
$map['id'] = array('not in','1,2,4');
//where 为`id` NOT IN ('1','2','4')
//EXP:自定义
$map['id'] = array('exp','in (1,2,4)');
//where 为`id` NOT IN ('1','2','4')
PS:使用exp 自定义在第二个参数直接写where 语句即可
//EXP:自定义增加OR 语句
$map['id'] = array('exp', '=1');
$map['user'] = array('exp', '="蜡笔小新"');
$map['_logic'] = 'OR';
//WHERE 为( (`id` =1) ) OR ( (`user` ="蜡笔小新") )

三.快捷查询

立即学习PHP免费学习笔记(深入)”;

快捷查询方式是一种多字段查询的简化写法,在多个字段之间用'|'隔开表示OR,用'&'
隔开表示AND。
1.不同字段相同查询条件
//使用相同查询条件
$user = M('User');
$map['user|eemail'] = 'a'; //'|'换成'&'变成AND
var_dump($user->where($map)->select());
2.不同字段不同查询条件
//使用不同查询条件
$user = M('User');
$map['id&user'] = array(1,'蜡笔小新','_multi'=>true);
var_dump($user->where($map)->select());
PS:设置'_multi'为true,是为了让id 对应1,让user 对应'蜡笔小新',否则就
会出现id 对应了1 还要对应'蜡笔小新'的情况。而且,这设置要在放在数组最后。
//支持使用表达式结合快捷查询
$user = M('User');
$map['id&user'] = array(array('gt', 0),'蜡笔小新','_multi'=>true);
var_dump($user->where($map)->select());

四.区间查询

ThinkPHP 支持对某个字段的区间查询。
//区间查询
$user = M('User');
$map['id'] = array(array('gt', 1), array('lt', 4));
var_dump($user->where($map)->select());
//第三个参数设置逻辑OR
$user = M('User');
$map['id'] = array(array('gt', 1), array('lt', 4), 'OR');
var_dump($user->where($map)->select());

五.组合查询

迅易年度企业管理系统开源完整版
迅易年度企业管理系统开源完整版

系统功能强大、操作便捷并具有高度延续开发的内容与知识管理系统,并可集合系统强大的新闻、产品、下载、人才、留言、搜索引擎优化、等功能模块,为企业部门提供一个简单、易用、开放、可扩展的企业信息门户平台或电子商务运行平台。开发人员为脆弱页面专门设计了防刷新系统,自动阻止恶意访问和攻击;安全检查应用于每一处代码中,每个提交到系统查询语句中的变量都经过过滤,可自动屏蔽恶意攻击代码,从而全面防止SQL注入攻击

下载

组合查询是基于索引数组查询方式的一个扩展性查询,添加了字符串查询(_string)、复
合查询(_complex)、请求字符串查询(_query),由于采用的是索引数组,重复的会被覆盖。
//字符串查询(_string)
$user = M('User');
$map['id'] = array('eq', 1);
$map['_string'] ='user="蜡笔小新" AND email="xiaoxin@163.com"';
var_dump($user->where($map)->select());
//请求字符串查询(_query)
$user = M('User');
$map['id'] = array('eq', 1);
$map['_query'] ='user=蜡笔小新&email=xiaoxin@163.com&_logic=OR';
var_dump($user->where($map)->select());
PS:这种方式是URL 方式,不需要加引号。
//复合查询(_complex)
$user = M('User');
$where['user'] = array('like', '%小%');
$where['id'] = 1;
$where['_logic'] = 'OR';
$map['_complex'] = $where;
$map['id'] = 3;
$map['_logic'] = 'OR';
var_dump($user->where($map)->select());
PS:复合查询可以构建更加复杂的查询,这里id=1 或者id=3 可以构建实现。

六.统计查询

ThinkPHP 提供了一些数据统计查询的方法。
//数据总条数
$user = M('User');
var_dump($user->count());
//字段总条数,遇到NULL不统计
$user = M('User');
var_dump($user->count('email'));
//最大值
$user = M('User');
var_dump($user->max('id'));
//最小值
$user = M('User');
var_dump($user->min('id'));
//平均值
$user = M('User');
var_dump($user->avg('id'));
//求总和
$user = M('User');
var_dump($user->sum('id'));

七.动态查询

借助PHP5 语言的特性,ThinkPHP 实现了动态查询。
1.getBy 动态查询
//查找email=xiaoin@163.com的数据
$user = M('User');
var_dump($user->getByemail('xiaoxin@163.com'));
2.getFieldBy 动态查询
//通过user得到相对应id值
$user = M('User');
var_dump($user->getFieldByUser('路飞', 'id'));

八.SQL 查询

ThinkPHP 支持原生SQL 查询。
1.query 读取
//查询结果集,如果采用分布式读写分离,则始终在读服务器执行
$user = M('User');
var_dump($user->query('SELECT * FROM think_user'));
2.execute写入
//更新和写入,如果采用分布式读写分离,则始终在写服务器执行
$user = M('User');
var_dump($user->execute('UPDATE think_user set user="蜡笔大新" WHERE
id=1'));
PS:由于子查询用了不少连贯操作,我们会在连贯操作讲解。

以上就介绍了ThinkPHP--SQL 查询语句,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1044

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

334

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

213

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

35

2026.02.13

Redis高可用架构与分布式缓存实战
Redis高可用架构与分布式缓存实战

本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

111

2026.02.13

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

77

2026.02.12

雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

17

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

813

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

97

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP函数之array数组函数视频讲解
PHP函数之array数组函数视频讲解

共76课时 | 26.2万人学习

Redis中文开发手册
Redis中文开发手册

共0课时 | 0人学习

SSDB数据库使用手册
SSDB数据库使用手册

共21课时 | 13.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号