ThinkPHP 模型方法 getField() 和 select() 使用技巧

getField() 使用技巧

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

获取某个字段值

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

// 实例化User对象
$User = M("User"); 

// 获取ID为3的用户的昵称
$nickname = $User->where(‘id=3‘)->getField(‘nickname‘);

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

获取某个字段列

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

// 实例化User对象
$User = M("User");

// 获取status为1的用户的昵称列表(昵称数组)
$nickname = $User->where(‘status=1‘)->getField(‘nickname‘, true);
// 返回数据格式如array(‘小明‘, ‘张三‘, ‘李四‘)一维数组,其中 value 就是 nickname 列的每行的值

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

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

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

或者

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

获取 2 个字段列表

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

// 实例化User对象
$User = M("User");

// 获取status为1的用户的昵称列表
$nickname = $User->where(‘status=1‘)->getField(‘id,nickname‘);
// 两个字段的情况下返回的是 array(‘id‘ => ‘nickname‘)的关联数组,以 id 的值为 key,nickname 字段值为 value

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

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

或者

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

获取多个字段列表

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

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

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

$result = $User->where(‘status=1‘)->getField(‘id,nickname,email‘,‘|‘);

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

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

select() 使用技巧

查询结果索引化

$result = $User->where(‘status=1‘)->select(array(‘index‘ => ‘id‘));
// 遍历结果,将 id 的值设为数组 key,如下所示
array(
    ‘1‘ => array(
        ‘id‘ => 1,
        ‘nickname‘ => ‘小明‘,
        ‘email‘ => ‘[email protected]‘,
        ‘age‘ => 9
    ),
    ‘2‘ => array(
        ‘id‘ => 2,
        ‘nickname‘ => ‘张三‘,
        ‘email‘ => ‘[email protected]‘,
        ‘age‘ => 26
    ),
     ‘3‘ => array(
        ‘id‘ => 3,
        ‘nickname‘ => ‘李四‘,
        ‘email‘ => ‘[email protected]‘,
        ‘age‘ => 26
    )
);
时间: 2024-08-18 02:50:05

ThinkPHP 模型方法 getField() 和 select() 使用技巧的相关文章

ThinkPHP 模型方法 setInc() 和 setDec() 使用详解

对于数字字段的加减,可以直接使用 setInc() 与 setDec() 方法 ThinkPHP 内置了对统计数据(数字字段)的更新方法: setInc():将数字字段值增加 setDec():将数字字段值减少 setInc() ThinkPHP setInc() 方法将数字字段值增加. 例子: <?php public function update() { header("Content-Type:text/html; charset=utf-8"); $result = M

(转)ThinkPHP find方法 查询一条数据记录

find() ThinkPHP find() 方法是和 select() 用法类似的一个方法,不同之处 find() 查询出来的始终只有一条数据,即系统自动加上了 LIMIT 1 限制. 当确认查询的数据记录只能是一条记录时,建议使用 find() 方法查询,如用户登录账号检测: public function chekUser(){ header("Content-Type:text/html; charset=utf-8"); $Dao = M("User");

ThinkPHP CURD方法中field方法详解

导读:ThinkPHP CURD方法的field方法属于模型的连贯操作方法之一,主要目的是标识要返回或者操作的字段,可以用于查询和写入操作. 1.用于查询在查询操作中field方法是使用最频繁的.$Model->field('id,title,content')->select(); 这里使用field方法指定了查询的结果集中包含id,title,content三个字段的值.执行的SQL相当于:SELECT id,title,content FROM table 当然,除了select方法之外

ThinkPHP CURD方法盘点:where方法

今天来给大家讲下查询最常用但也是最复杂的where方法,where方法也属于模型类的连贯操作方法之一,主要用于查询和操作条件的设置.where方法的用法是ThinkPHP查询语言的精髓,也是ThinkPHP ORM的重要组成部分和亮点所在,可以完成包括普通查询.表达式查询.快捷查询.区间查询.组合查询在内的查询操作.where方法的参数支持字符串和数组,虽然也可以使用对象但并不建议. 字符串条件 使用字符串条件直接查询和操作,例如: $User = M("User"); // 实例化U

ThinkPHP 模型(Model)命名规范

一个小问题搞了好久:如果数据库的表名中有下划线,那么在用thinkphp做自动完成时注意Model类的命名要变成驼峰法,文件名和类名都要变.( 另外注意:只有使用create方法创建数据时才能调用到自动验证和自动完成 ) ThinkPHP 模型(Model)命名规范 模型命名规范ThinkPHP 对数据库的表名和模型类的命名遵循一定的规范.首先数据库的表名和字段全部采用小写形式,模型类的命名规则是除去表前缀的数据表名称,并且首字母大写,然后加上模型类的后缀定义.一些例子如下:表名(不含前缀)模型

ThinkPHP快捷方法汇总(随时添加)

读取配置 C('参数名称') 例如,读取当前的URL模式配置参数: $model = C('URL_MODEL'); // 由于配置参数不区分大小写,因此下面的写法是等效的 // $model = C('url_model'); C方法也可以用于读取二维配置: //获取用户配置中的用户类型设置 C('USER_CONFIG.USER_TYPE'); 因为配置参数是全局有效的,因此C方法可以在任何地方读取任何配置,即使某个设置参数已经生效过期了. 动态配置 设置格式:C('参数名称','新的参数值

thinkphp U方法生成链接没有host

今天将自己代码传到线上服务器,页面上用到很多thinkphp U() 方法生成的链接.本地测试没啥问题,到线上发现链接生成的不对,每个都没有了host 每个链接多个index,然后查看tp的U方法: $url    =   __APP__.'/'.($module?$module.MODULE_PATHINFO_DEPR:'').implode($depr,array_reverse($var)); 是因为__APP__这里的原因,然后找到__APP__赋值的地方: define('__APP_

稀疏数据压缩查询方法:Rank &amp; Select 操作

1.稀疏数据的例子 对于网络图对应的节点关联矩阵.数据生成的哈希表等,这些存储起来是稀疏的,这样我们就会想到需要压缩空间.但是在压缩存储空间的同时,还要支持高效的查询操作. Rank & Select 就可以对稀疏的数据进行压缩,还能支持高效的查询操作. 2.Rank & Select 操作压缩稀疏数据原理 以下图为例子,假如是经过哈希后得到的哈希数组: 构造数组A和B: Vec-A:1010100110001    (每个位置一个比特位,1:有数据,0:无数据)  Num-B:12  2

SP3D导出模型方法

SP3D导出模型方法 SP3D是后台驱动的三维设计软件,所有的三维模型以数据的形式存在数据库,模型文件只能使用只带的功能或者接口进行输出.目前只支持VUE/SAT/DGN的格式. 本文以SAT为例子介绍SP3D内部设计的三维模型导出. 打开Drawing and Reports专业: 在Drawungs模块选择右键New 菜单: 选择新建的类型为3D Model Data: 新建完毕后可以将配置名称修改: 对新建的配置右键选择Setup操作: Setup弹出的界面如下: 1)        选择