ThinkPHP之getField详解

 更新时间:2014年06月20日 12:11:58   投稿:shichen2014  
这篇文章主要介绍了ThinkPHP的getField方法,需要的朋友可以参考下

getField方法是ThinkPHP中用来获取字段值的方法,区别于select和find方法,通常仅用于获取个别字段的值。但是事实上并没有那么简单,现将该方法的用法总结如下:

1.获取某个字段值

这个是getField方法最基本的用法,用于获取符合条件的某个字段值。

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

返回的nickname是一个字符串结果。也就是说,即使有满足条件的多个字段,也只会返回一个结果。

2.获取某个字段列

如果希望返回符合要求的字段列(多个结果),可以使用:

$User = M("User"); // 实例化User对象
 // 获取status为1的用户的昵称列表
$nickname = $User->where('status=1')->getField('nickname',true);

第二个参数传入了true,返回的nickname则是一个数组,包含了所有满足条件的昵称列表。

如果需要限制返回结果数量,可以使用:

$nickname = $User->where('status=1')->getField('nickname',8);

或者

$nickname = $User->where('status=1')->limit(8)->getField('nickname',true);


3.获取2个字段列表

如果希望获取满足条件的id和昵称列表,则可以使用:

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

如果getField方法传入多个字段名称的话,默认返回一个关联数组,以第一个字段的值为索引(所以第一个字段要尽量选择不会重复的)。
也可以限制返回数量,例如:

$nickname = $User->where('status=1')->getField('id,nickname',8);

或者

$nickname = $User->where('status=1')->limit(8)->getField('id,nickname');


4.获取多个字段列表

如果传入了2个以上的字段名,则返回一个二维数组(类似select方法的返回值,区别在于索引是二维数组的键名是第一个字段的值),例如:

$result = $User->where('status=1')->getField('id,account,nickname');

如果不希望返回二维数组,可以使用连接符,例如:

$result = $User->where('status=1')->getField('id,account,nickname',':');

那么返回的结果则是一个索引数组,键名是id值,键值则是account:nickname连接组成的字符串。

getField方法通常还可以配合连贯操作where、limit、order等一起使用。还有一些高级的用法,包括对join表的支持和sql方法的支持等。

更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《smarty模板入门基础教程》及《PHP模板技术总结》。

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

相关文章

  • yii2组件之下拉框带搜索功能的示例代码(yii-select2)

    yii2组件之下拉框带搜索功能的示例代码(yii-select2)

    本篇文章主要介绍了yii2组件之下拉框带搜索功能的示例代码(yii-select2),具有一定的参考价值,有兴趣的可以了解一下
    2017-09-09
  • thinkphp模板输出技巧汇总

    thinkphp模板输出技巧汇总

    这篇文章主要介绍了thinkphp模板输出技巧,实例汇总了变量输出、系统变量、运算符等常用是输出技巧,非常具有实用价值,需要的朋友可以参考下
    2014-11-11
  • thinkphp实现多语言功能(语言包)

    thinkphp实现多语言功能(语言包)

    这篇文章主要介绍了thinkphp实现多语言功能(语言包),需要的朋友可以参考下
    2014-03-03
  • PHP获取真实IP及IP模拟方法解析

    PHP获取真实IP及IP模拟方法解析

    这篇文章主要介绍了PHP获取真实IP及IP模拟方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-11-11
  • php之app消息推送案例教程

    php之app消息推送案例教程

    这篇文章主要介绍了php之app消息推送案例教程,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • Laravel框架实现点播上传阿里云功能

    Laravel框架实现点播上传阿里云功能

    这篇文章主要介绍了Laravel框架实现点播上传阿里云功能,本文给大家分享一段完整的实例代码,代码简单易懂,需要的朋友可以参考下
    2021-09-09
  • php实现读取内存顺序号

    php实现读取内存顺序号

    这篇文章主要介绍了php实现读取内存顺序号,十分的简单实用,需要的朋友可以参考下
    2015-03-03
  • ThinkPHP框架基于PDO方式连接数据库操作示例

    ThinkPHP框架基于PDO方式连接数据库操作示例

    这篇文章主要介绍了ThinkPHP框架基于PDO方式连接数据库操作,结合完整实例形式分析了thinkPHP使用PDO方式连接数据库的相关配置、控制器及模板调用相关操作技巧,需要的朋友可以参考下
    2018-03-03
  • php获取访问者浏览页面的浏览器类型

    php获取访问者浏览页面的浏览器类型

    最近做的项目需要根据用户浏览器的类型而做一些不同的处理,于是稍微研究了一下使用php判断浏览器类型的方法,下面这篇文章主要给大家介绍了php如何获取访问者浏览页面的浏览器类型,需要的朋友可以参考借鉴,一起来看看吧。
    2017-01-01
  • Laravel框架中自定义模板指令总结

    Laravel框架中自定义模板指令总结

    Blade 允许你自定义命令,你可以使用 directive 方法注册命令。下面这篇文章主要给大家总结介绍了关于Laravel框架中自定义模板指令的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧
    2017-12-12

最新评论