ThinkPHP中框架查询
1.查询多条数据
1.1静态调用all方法或者select方法
// 获取所有数据 all 和 select
$list = User::all();
// 根据主键获取多个数据all 和 select where id in (1,2,3)
$list = User::all('1,2,3');
$list = User::all([1,2,3]);
//或者使用数组查询(只能用all不能用select) where status = 1
$list = User::all(['status'=>1]);
1.2动态调用all方法或者select方法
$user = new User();
//查询所有数据all 和 select
$list = $user->select();
//根据主键查询多条数据all 和 select
$list = $user->select('1,2,3');
$list = $user->select([1,2,3]);
//或者使用数组查询(只能用all不能用select)
$list = $user->all(['status'=>1]);
注:all方法或者select方法返回的是一个包含模型对象的二维数组或者空数组select方法和All方法的应用:[obj, obj]
2.查询一条数据
2.1静态调用get方法或者find方法
//取出主键为1的数据 where id = 1 $user = \app\admin\model\User::get(1); $user = \app\admin\model\User::find(1); //使用数组查询(非主键字段),只能用get不能用find where name = 'thinkphp' $user = User::get(['name' => 'thinkphp']); //取出第一条数据,只能用find不能用get $user = User::find();
2.2动态调用get方法或者find方法
$user = new User(); //取出主键为1的数据 $info = $user->find(1); $info = $user->get(1); //使用数组查询(非主键字段),只能用get不能用find $info = $user->get(['name' => 'thinkphp']); //取出第一条数据,只能用find不能用get $info = $user->find();
注:get或者find方法返回的是当前模型的对象实例或者null返回的模型对象,可以直接当做数组使用,也可以调用toArray() 直接转化为数组。find方法和Get方法的应用:
3.其他查询方法
3.1where方法
$info = User::where('id','=','1')->find();
$info = User::where('id','1')->find();
$info = User::where('name','like','%thinkphp%')->select();
3.2链式操作
$model = new Address();
$model->field('id
name')->select(); //指定要查询的字段,原生sql中select后面的字段
$model->order('id desc,time desc')->select(); //相当于原生sql中的order by
$model->limit(3)->select(); //相当于原生sql中的limit条件
$model->limit(0,3)->select();
$model->limit('0,3')->select();
$model->group('cate_id')->select(); //相当于原生sql中的group by
$model->having('id>3')->select(); //相当于原生sql中的having条件
$model->alias('a')->join('think_user_type t','a.id=t.user_id', 'left')->select(); //alias方法设置别名,join方法连表查询
3.3聚合查询
在模型中也可以调用数据库的聚合方法进行查询
3.4数据字段查询
查询一条记录的一个字段的值
Goods::where(‘id’, 2)->value(‘goods_name’);
查询多条记录的一个字段的值,返回一个一维索引数组
Goods::where(‘id’, ‘GT’, 2)->column(‘goods_name’);
查询多条记录的一个字段的值,以id字段值作为数组索引
Goods::where(‘id’, ‘GT’, 2)->column(‘goods_name’, ‘id’);
ThinkPHP中框架查询的更多相关文章
- THINKPHP 中关联查询(多表查询)
THINKPHP 中关联查询(多表查询)可以使用 table() 方法或和join方法,请看示例: 1.Table方法:定义要操作的数据表名称,可以动态改变当前操作的数据表名称,需要写数据表的全名,包 ...
- thinkphp中的查询语句
<?php namespace Admin\Controller; use Think\Controller; class MainController extends Controller { ...
- ThinkPHP(3)SQL查询语句
ThinkPHP中对查询语句,包含了基本的查询方式.表达方式.快速查询.区间查询.组合查询.SQL查询.动态查询和子查询. 一.查询方式 ThinkPHP提供了三种基本的查询方式:字符串条件查询.索引 ...
- ThinkPHP中 按条件查询后列表显示
最近在项目中遇到了需要根据下拉框的条件筛选出符合条件的数据,然后进行列表显示的问题. 在ThinkPHP中进行列表显示的传统过程:通过在后台控制器中查询出数据,然后通过$this->assign ...
- Thinkphp中查询复杂sql查询表达式,如何表达MYSQL中的某字段不为空is not null?
Thinkphp中查询复杂sql查询表达式,如何表达MYSQL中的某字段不为空is not null?先上两种实现方式的实例:$querys["house_type_image"] ...
- thinkphp中如何是实现多表查询
多表查询经常使用到,但如何在thinkphp中实现多表查询呢,其实有三种方法. 1 2 3 4 5 6 7 8 9 10 11 12 // 1.原生查询示例: $Model = new Model() ...
- TP框架中field查询字段
TP框架中field查询字段 不是fields 也不是files !!!! 不是fields 也不是files !!!! 不是fields 也不是files !!!! 不是fields 也不是file ...
- TP框架中模糊查询实现
TP框架中模糊查询实现 $where['g.name'] = array('like','%'.$groupname.'%'); 表达式查询 上面的查询条件仅仅是一个简单的相等判断,可以使用查询表达式 ...
- TP框架---thinkphp中ajax分页
//点击类别后要显示的内容 public function pagechuli3()//这个方法的功能是根据ajax传过来的值查询数据,再将查询出来的数据返回到ajax,返回的默认是JSON类型. { ...
随机推荐
- Real World CTF一日游
今天去感受了长亭举办的RWCTF现场,参加了技术论坛,也学到了很多的知识 比较有印象的就是 智能安全在Web防护中的探索和实践 阿里云安全防护构建的AI架构体系: 基线检测 基础过滤 异常检测 攻击识 ...
- mybatis源码学习(二)--mybatis+spring源码学习
这篇笔记主要来就,mybatis是如何利用spring的扩展点来实现和spring的整合 1.mybatis和spring整合之后,我们就不需要使用sqlSession.selectOne()这种方式 ...
- Python 库打包分发、setup.py 编写、混合 C 扩展打包的简易指南(转载)
转载自:http://blog.konghy.cn/2018/04/29/setup-dot-py/ Python 有非常丰富的第三方库可以使用,很多开发者会向 pypi 上提交自己的 Python ...
- 【每天一题】LeetCode 0067. 二进制求和
开源地址:https://github.com/jiauzhang/algorithms 题目描述 * https://leetcode-cn.com/problems/add-binary * 给定 ...
- Winform中实现自定义屏保效果(附代码下载)
场景 效果 注: 博客主页: https://blog.csdn.net/badao_liumang_qizhi 关注公众号 霸道的程序猿 获取编程相关电子书.教程推送与免费下载. 实现 新建form ...
- Redis集群与分布式介绍以及搭建Redis-Cluster
1 Redis集群 1.1 什么是集群 集群就是很多服务器组成的一个网络.指的是将多台服务器集中在一起,实现同一业务. 1.2 为什么要集群 一台服务器不能满足开发需要的时候,需要多台服务器来支持.这 ...
- 集合系列 Map(十三):LinkedHashMap
我们之前说过 LinkedHashMap 是在 HashMap 的基础上,增加了对插入元素的链表维护.那么其到底是怎么实现的呢?今天这篇文章就带我们来一探究竟. public class Linked ...
- 自己封装Linux命令行万能解压命令
问题背景 Linux下经常需要解压文件,直接在命令行敲命令解压是最便捷的. 但问题在于,不同的压缩格式,需要用不同命令和不同参数,完全记不住啊. 解决方式 既然记不住,那就换一种思路,假如有一条命令能 ...
- 精通awk系列(3):铺垫知识:读取文件的几种方式
回到: Linux系列文章 Shell系列文章 Awk系列文章 读取文件的几种方式 读取文件有如下几种常见的方式: 下面使用Shell的read命令来演示前4种读取文件的方式(第五种按字节数读取的方式 ...
- Iterable与Collection源码学习
接口 - Iterable<T> - 可迭代 描述 实现本接口的类,其对象可以被迭代.同时支持forEach语法 方法 Iterator<T> iterator() 类型 抽象 ...