文档章节

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
博文 62
码字总数 31743
作品 0
西安
程序员

暂无文章

基于TP5的微信的公众号获取登录用户信息

之前讲过微信的公众号自动登录的菜单配置,这次记录一下在TP5项目中获取自动登录的用户信息并存到数据库的操作 基本的流程为:微信设置自动登录的菜单—>访问的URL指定的函数里获取用户信息—...

月夜中徘徊
今天
0
0
youTrack

package jetbrains.teamsys.license.runtime; 计算lis package jetbrains.ring.license.reader; 验证lis 安装后先不要生成lis,要把相关文件进行替换 ring-license-checker-1.0.41.jar char......

max佩恩
今天
0
0
12.17 Nginx负载均衡

Nginx负载均衡 下面的dig看到可以返回2个IP,就是解析出来的IP,这样我们可以做负载均衡。 dig www.qq.com 1.vim /usr/local/nginx/conf/vhost/fuzai.conf 2.添加如下配置 upstream qq //定义...

芬野de博客
今天
0
0
SSE(Server Send Event 服务端发送事件)

package com.example.demo.controller;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;import org.springframe......

Canaan_
今天
0
0
jvm调优

1.jvm运行模式 client模式:启动快,占用内存少,jit编译器生成代码的速度也更快. server模式:主要优势在于代码优化功能,这个功能对于服务器应用而言尤其重要. tiered server模式:结合了client与...

Funcy1122
今天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部