文档章节

总结thinkphp快捷查询getBy、getField、getFieldBy用法及场景

白俊遥
 白俊遥
发布于 2016/05/14 11:30
字数 1286
阅读 9
收藏 1
点赞 2
评论 0

thinkphp作为国内现阶段最成熟的框架;没有之一;

不得不说是有好些特别方便的方法的;

然而如果初接触thinkphp的时候难免会被搞的有点迷茫;

for example这些:

getBy

getField

getFieldBy

我曾在相当一段时间内都用的迷迷糊糊的;

直到后来把它们总结如下:

咱先虚拟一张表出来

+----+--------+--------------+
| id | name   | avatar              |
+----+--------+--------------+
|  1 | 白俊遥  | bjy.jpg             |
|  2 | 帅白     | shuaibai.jpg     |
|  3 | test      | shuaibai.jpg     |
+--+-------+----------------+

 

一:现在我们要获取姓名为 白俊遥 的这条数据;

常规情况是这样写的;

$data=M('Test')->where(array('name'=>'白俊遥'))->find()

如果用getby的话就可以简化为

$data=M('Test')->getByName('白俊遥');//通过name字段获取整条数据
$data=M('Test')->getByAvatar('bjy.jpg')//同理可得如果想通过avatar获取整条数据就是这样写了
$data=M('Test')->getById(1);//聪明的童鞋立即就想到了如果要通过id那不就是这样?对;
                            //但是如果id是主键的话;这里有个更好用的方法
$data=M('Test')->find(1);//得到的结果和M('Test')->getById(1);是一样的
打印值:
Array
(
    [id] => 1
    [name] => 白俊遥
    [avatar] => bjy.jpg
)

官方详细文档:http://document.thinkphp.cn/manual_3_2.html#dynamic_query

总结就是说;getBy后边是要跟一个字段的;

我们也发现了;上面获取到的都是整条整条的数据;

二:然而实际开发中;很多时候我们是想通过用户名:白俊遥 找到他的头像:bjy.jpg;

这时候就是getFieldBy的应用场景了;

常规情况是这样写的;

$data=M('Test')->field('avatar')->where(array('name'=>'白俊遥'))->find();
$avatar=$data['avatar'];

如果用getField的话可以简化为:

$avatar=M('Test')->where(array('name'=>'白俊遥'))->getField('avatar');

如果getFieldBy那简化的更残忍了:

$avatar=M('Test')->getFieldByName('白俊遥','avatar');
打印$avatar:
bjy.jpg

官方详细文档:http://document.thinkphp.cn/manual_3_2.html#dynamic_query

总结就是说getFieldBy后面跟一个字段括号内有两个参数;第一个跟Field对应的条件;第二个是要取的字段;

三:通过头像名 shuaibai.jpg 获取使用这个头像的用户名 帅白、test

常规是这样写的:

$data=M('Test')->field('name')->where(array('avatar'=>'shuaibai.jpg'))->select();
$name_array=array_column($data, 'name');

如果getField的话就可以简化为:

$avatar_array=M('Test')->where(array('avatar'=>'shuaibai.jpg'))->getField('name',true);
打印$avatar_array:
Array
(
    [0] => 帅白
    [1] => test
)

官方详细文档:http://document.thinkphp.cn/manual_3_2.html#read_data 

总结就是说:getField是需要自己写where的;传的第一个参数就是需要获取的字段;

如果只获取一条值的时候不需要传第二个参数;如果有多个的话;则第二个参数传true;

更详细的用法偷个懒直接复制官方文档了:

读取字段值其实就是获取数据表中的某个列的多个或者单个数据,最常用的方法是 getField方法。

示例如下:

$User = M("User"); // 实例化User对象
// 获取ID为3的用户的昵称 $nickname = $User->where('id=3')->getField('nickname');

默认情况下,当只有一个字段的时候,返回满足条件的数据表中的该字段的第一行的值。

如果需要返回整个列的数据,可以用:

$User->getField('id',true); // 获取id数组
//返回数据格式如array(1,2,3,4,5)一维数组,其中value就是id列的每行的值

如果传入多个字段的话,默认返回一个关联数组:

$User = M("User"); // 实例化User对象
// 获取所有用户的ID和昵称列表 $list = $User->getField('id,nickname');
//两个字段的情况下返回的是array(`id`=>`nickname`)的关联数组,
以id的值为key,nickname字段值为value

这样返回的list是一个数组,键名是用户的id字段的值,键值是用户的昵称nickname。

如果传入多个字段的名称,例如:

$list = $User->getField('id,nickname,email');
//返回的数组格式是array(`id`=>array(`id`=>value,`nickname`=>value,`email`=>value))
是一个二维数组,key还是id字段的值,但value是整行的array数组,
类似于select()方法的结果遍历将id的值设为数组key

返回的是一个二维数组,类似select方法的返回结果,区别的是这个二维数组的键名是用户的id(准确的说是getField方法的第一个字段名)。

如果我们传入一个字符串分隔符:

$list = $User->getField('id,nickname,email',':');

那么返回的结果就是一个数组,键名是用户id,键值是 nickname:email的输出字符串。

getField方法还可以支持限制数量,例如:

$this->getField('id,name',5); // 限制返回5条记录
$this->getField('id',3); // 获取id数组 限制3条记录

可以配合使用order方法使用。更多的查询方法可以参考查询语言章节。

认真写一篇博客真心不容易;写着写着就熬到了凌晨1点了;但愿能让童鞋们少走一些弯路;也算不枉这么辛苦的码字;

白俊遥博客

 

本文为白俊遥原创文章,转载无需和我联系,但请注明来自白俊遥博客http://www.baijunyao.com                        

© 著作权归作者所有

共有 人打赏支持
白俊遥
粉丝 15
博文 58
码字总数 28701
作品 1
朝阳
程序员
ThinkPHP 查询数据 select(findAll) 方法

ThinkPHP 查询数据 ThinkPHP 查询数据主要提供以下几类查询: select:普通查询,同 findAll() 方法 find:取得符合查询条件的一条记录 getBy动态查询:根据某个字段取得符合查询条件的一条记...

WangEven
2012/05/10
0
0
ThinkPHP 学习笔记 (二) Model模型操作

一、Model类中的部分属性意义及设定 tableName 属性 当表前缀和系统设置的前缀(DB_PREFIX)一致而表名和模型名称不一致时,可设置此属性,例如表名称为 users ,而模型名称为 UserModel ,那...

bugyang
2013/02/19
0
0
ThinkPHP3.0新特性: 快捷查询

新版增加了快捷查询方式,可以进一步简化查询条件的写法,例如: 一、实现不同字段相同的查询条件 $User = M("User"); // 实例化User对象 $map['name|title'] = 'thinkphp'; // 把查询条件传...

岭南六少
2012/02/27
0
0
ThinkPHP getBy动态查询

getBy动态查询 ThinkPHP getBy动态查询是一个魔术方法,可以根据某个字段名称动态得到对应的一条数据记录。 根据用户名(username)查询对应的用户资料记录: public function chekUser(){ ...

WangEven
2012/05/10
0
0
ThinkPHP的CURD操作

CURD:create(创建)、update(更新)、read(读取)、delete(删除) 1.数据对象创建(create): a.TP提供了create方法迅速的创建数据对象,可一自动的根据表单数据创建对象,支持数组,对象,甚至可...

笨小熊
2015/06/29
0
0
纯PHP Codeigniter(CI) ThinkPHP效率测试

最近一直想做一个技术类的新闻站点,想做的执行效率高些,想用PHP做,一直纠结于用纯PHP做还是用CI或者THINKPHP。用纯PHP效率高,缺点n多,比如安全方面、构架方面等等等等;用CI、thinkPHP的...

木川瓦兹
2012/11/05
0
18
ThinkPHP where方法:设置查询或操作条件

ThinkPHP where() ThinkPHP where()方法是 Model 类内置方法,用于设置数据库查询或者更新、删除等操作条件。 where 方法支持以字符串、数组和对象方式来设置条件,该方法不能独立使用,必须...

WangEven
2012/05/10
0
0
Thinkphp下实现对数组的分页

今天终于把两周之前的任务完成了,趁着余热记下来分享给大家。 说一下任务,在thinkphp的框架下实现分页。公司的网站基于Thinkphp框架,一直久闻thinkphp的大名,终于有机会实战了。 thinkp...

zhang_go
2014/04/09
0
1
ThinkPHP单字母函数(快捷方法)使用总结

ThinkPHP单字母函数(快捷方法)使用总结 投稿:shichen2014 字体:[增加 减小] 类型:转载 时间:2014-07-23 这篇文章主要介绍了ThinkPHP单字母函数(快捷方法)使用总结,对ThinkPHP的快捷方法做...

thinkyoung
2015/09/06
0
0
ThinkPHP 3.2 版本升级了哪些内容

ThinkPHP 3.2 版本升级了哪些内容 ThinkPHP 3.2发布了挺长时间了,这里也总结下这次ThinkPHP 3.2到底发生了哪些变化,方便程序员们进行开发。 前言 ThinkPHP 3.2 基于 ThinkPHP 3.1 的基础上...

thinkyoung
2015/10/15
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

java的反射机制理解

一、概念说明 java的反射机制,是在运行状态下,可以动态获取任意一个类的属性和方法;可以动态调用一个对象任意方法; 二、反射相关类 java.lang.Class; //类 java.lang.re...

盼望明天
11分钟前
0
0
nginx反向代理-多端口映射

代码解释 1.1 http:www.baidu.test.com默认是80,访问“/”利用反向代理,然后访问本地8083; 1.2 8083代表本地的前端工程访问地址,前端需要访问后台数据,”/”,继续代理到后台地址9803; ...

lilugirl
13分钟前
0
0
Jfinal使用log4j2打印日志

1,添加maven配置 <properties><log4j2.version>2.11.0</log4j2.version><slf4j.version>1.7.25</slf4j.version></properties> <!--slf4j及log4j2日志 --><dependency> ......

iborder
14分钟前
0
0
如何在Rancher 2.0上快速部署Datadog

Datadog是一种流行的托管监控解决方案,用于聚合和分析分布式系统的指标和事件。从基础架构集成到协作仪表板,Datadog为用户提供了一个简洁的单一窗格视图,用户可以快速查看对其最重要的信息...

RancherLabs
16分钟前
0
0
Java示例演示Functor 和monad

This article was initially an appendix in our Reactive Programming with RxJavabook. However introduction to monads, albeit very much related to reactive programming, didn't suit......

Quan全
35分钟前
0
0
微信官方jssdk Demo

1.html部分 <!DOCTYPE html><!-- saved from url=(0028){sh:$selfUrl} --><html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <meta charset="utf-8"......

koloor
38分钟前
1
0
数据库命名规范

https://www.cnblogs.com/pangguoming/p/7126512.html 摘要:当前研发工作中经常出现因数据库表、数据库表字段格式不规则而影响开发进度的问题,在后续开发使用原来数据库表时,也会因为数据...

塔塔米
38分钟前
0
0
java https 请求工具类-通用

package com.ra.common.util; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.OutputStreamWriter; import java.io.PrintW......

轻量级赤影
39分钟前
0
0
MFC界面套包BCG Pro Edition for MFC正式发布v27.3|附下载

BCGControlBar Professional Edition for MFC是MFC的一个扩展库,您可以用来构建类似于Microsoft Office 2000/XP/2003/2007/2010/2013 和 Microsoft Visual Studio-like(打印、用户定制工具......

Miss_Hello_World
39分钟前
0
0
Spring Cloud云服务 - HongHu架构common-service 项目构建过程

上一篇我们介绍了《整合spring cloud云服务架构 - HongHu云架构common-service代码结构分析》,本节我们将对common-service整个项目进行剖析,将整个构建的流程给记录下来,让更多的关注者来...

itcloud
40分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部