ThinkPHP 模型方法 getField() 和 select() 使用技巧
方法 技巧 模型 SELECT thinkphp 使用
2023-09-14 08:57:26 时间
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' => 'xiaoming@163.com', 'age' => 9 ), '2' => array( 'id' => 2, 'nickname' => '张三', 'email' => 'zhangsan@163.com', 'age' => 26 ), '3' => array( 'id' => 3, 'nickname' => '李四', 'email' => 'lisi@163.com', 'age' => 26 ) );
相关文章
- 毕业论文摘要的书写方法和技巧
- 异步加载js文件的方法总结
- 使用jquery的方法和技巧2,点击多选框的jquery响应
- 使用jquery的方法和技巧
- Java - Intellij IDEA的使用方法和技巧
- mysql ERROR 1045 (28000): Access denied for user解决方法
- hadoop大数据——mapreduce程序提交运行模式及debug方法
- 正则表达式Regex类常用方法
- 面向对象的 ABAP 编程初探 - 什么是类,实例,和 Public 方法
- 一个查看 SAP UI5 控件所有公有方法的小技巧
- 一起学微软Power BI系列-使用技巧(2)连接Excel数据源错误解决方法
- Atitit.实现继承的原理and方法java javascript .net c# php ...
- Py之pyinstaller:pyinstaller的简介、安装、使用方法(如去除cmd黑框、隐藏导入的模块等经验技巧)之详细攻略
- Python之matplotlib:基于matplotlib库利用python语言实现一张画布显示多张图的多种方法
- Python IDE之Pydev: 基于Eclipse搭建python的编译环境(Eclipse+pydev)简介、安装、使用技巧方法集合之详细攻略
- 【Java技巧 第6章】Java中BigDecimal 类的创建对象方法,介绍,常用方法以及8种舍入模式
- Linux 技巧:让进程在后台可靠执行的几种方法
- 1038. 从二叉搜索树到更大和树-dfs方法
- js判断空对象的方法
- Android 使用 DownloadManager 管理系统下载任务的方法,android管理系统
- 超级简单的方法重装Win11系统
- JavaScript学习总结-技巧、有用函数、简洁方法、编程细节
- git stash命令的使用方法
- XAI/ML之LIME:可解释性之SP-LIME的简介、原理、使用方法、经典案例之详细攻略
- 【项目实战】IDEA中的代码模板,IDEA如何导入签名,设置类头注释和方法注释
- 总结Tomcat优化方法
- python使用技巧(二十四):彻底学会argparse与sys.argv方法
- Python使用技巧(十五):静态类方法@staticmethod和@classmethod
- C++使用技巧(十二):命令行参数使用方法main(int argc, char *argv[])