文档章节

ThinkPHP 定位查询

ywppengpeng
 ywppengpeng
发布于 2016/11/21 13:47
字数 554
阅读 10
收藏 1

定位查询

ThinkPHP 支持对数据的定位查询:

  1. getN():取得查询结果中的某个位置的记录
  2. first():取得符合条件的第一条记录
  3. last():取得符合条件的最后一条记录

定位查询是内置于高级模型类(AdvModel)里的方法,是独立的方法且支持连贯操作。如果直接使用M或D实例化模型会提示:

Model:getN您所请求的方法不存在!

因此要使用定位查询需要加载高级模型类,可以有下面两种方法加载高级模型类:

1、使用动态模型切换 switchModel() 方法:

switchModel("Adv")

2、在用户模型里面继承高级模型类:

class UserModel extends AdvModel{ }

getN()

switchModel()

下面是使用 switchModel() 方法定位查询的例子:

public function read(){
    $Dao = M('User');
    $list = $Dao->switchModel('Adv')->where('uid > 0')->order('uid ASC')->getN(2);
    dump($list);
}

上例中用于取得 uid>0 的第3条记录。实际执行的 SQL 如下:

SELECT * FROM user WHERE uid > 0 ORDER BY uid ASC LIMIT 2,1

因此 getN() 中的参数是 LIMIT 中的第一个参数(游标偏移量)。

AdvModel

在 Lib/Model/UserModel.class.php 文件中定义模型如下:

<?php
class UserModel extends AdvModel{

}
?>

由于不需要再模型类实现任何逻辑,因此可以是一个空模型。控制器中代码如下:

public function read(){
    $Dao = D('User');
    $list = $Dao->where('uid > 0')->order('uid ASC')->getN(2);
    dump($list);
}

执行的效果和使用 switchModel() 一致。

first()

first() 方法用于获取符合条件的第一条记录,是高级模型类里面的方法,可以参考 getN() 的用法。

下面是使用 switchModel() 方法定位查询的例子:

public function read(){
    $Dao = M('User');
    $list = $Dao->switchModel('Adv')->where('uid > 10')->order('uid ASC')->first();
}

该方法实际是执行 getN(0) 方法。

last()

last() 方法用于获取符合条件的最后一条记录,是高级模型类里面的方法,可以参考 getN() 的用法。

下面是使用 switchModel() 方法定位查询的例子:

public function read(){
    $Dao = M('User');
    $list = $Dao->switchModel('Adv')->where('uid > 10')->order('uid ASC')->last();
}

该方法实际是执行 getN(-1) 方法。

参考阅读

  1. MySQL 统计查询》系列教程
  2. ThinkPHP Where 条件
  3. ThinkPHP 连贯操作

© 著作权归作者所有

共有 人打赏支持
ywppengpeng
粉丝 5
博文 63
码字总数 32377
作品 0
西安
程序员
私信 提问

暂无文章

Linux学习-1031(rsync同步工具 上)

10.28 rsync工具介绍 10.29/10.30 rsync常用选项 10.31 rsync通过ssh同步 一、 rsync工具介绍 rsync是一个同步工具,在日常的运维中常会用到。它可以本地同步,也实现可以远程两台机器同步。...

wxy丶
4分钟前
0
0
python实战一期:第一天

1. 为什么学习python 1.1 为什么要学Python? Python第一是个非常牛B的脚本语言,能满足绝大部分自动化运维的需求,又能做后端C/S架构,又能用WEB框架快速开发出高大上的Web界面,只有当你自...

laoba
6分钟前
1
0
Java并发编程学习三:线程同步的关键字以及理解

上篇文章中介绍了Java线程的带来的问题与内存模型中介绍了线程可能会引发的问题以及对应Java的内存模型,顺带介绍了Volatile和Sychronized关键字。今天对Java中涉及到的常见的关键类和关键字...

JerryLin123
13分钟前
0
0
我用代码来给你们分析一个赚钱的技巧

赚钱是个俗气的话题,但又是人人都绕不开的事情。我今天来“科学”地触碰下这个话题。 谈赚钱,就会谈到理财、投资,谈到炒股。有这样一个笑话: 问:如何成为百万富翁? 答:带一千万进入股...

crossin
13分钟前
0
0
spring MatchingBean应用

1、编写接口FactoryList import java.util.List;public interface FactoryList<E extends MatchingBean<K>, K> extends List<E> { E getBean(K factor); List<E> getBeanLi......

重城重楼
26分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部