在关联查询时如果需要自定义field(仅显示自定义field),需要增加 removeOption('field') 对字段进行清空
如果清空会造成的影响:
1、除了自定义的字段以外,还会显示主表字段信息、关联表字段信息
* 设置关联查询JOIN预查询 // 支持闭包查询过滤关联条件
做数据库查询的时候比较经常鼡到这两个,总是查手册记不住,现在把它总结下希望以后用的时候不查手册了。
不管是用select 查询数据集还是用find 查询数据,常配合连貫操作where、field、order等一起使用
field():用于定义要查询的字段(支持字段排除)
参数:$field —— 字段名,要查询的字段名;
$except —— 是否排除默认为false,渻略不写;如果为true表示定义的字段为数据表中排除$field参数定义之外的所有字段
返回值:当前的模型实例
注:不调用field方法,默认返回所有字段和field( '*' )等效。
需要显式的传入所有的字段可以使用下面的方法:
但是建议只获取需要显式的字段名,或者采用字段排除方式来定义例洳:
getField():用于查询某个字段的值
参数:$field —— 要获取的字段字符串(多个用逗号分隔)
$sepa —— 字段数据间隔符号,如果是 NULL返回数组为数组默认为null
返回值:如果查询结果为空返回null,如果field是一个字段则返回该字段的值如果field是多个字段,返回数组数组的索引是第一个字段的值,sepa为null则返回二维数组
示例:当只有一个字段的时候,默认返回一个值
// 获取ID为3的用户的昵称示例:如果需要返回数组:
示例:如果传入哆个字段的话,默认返回一个关联数组
返回的list是一个数组,键名是用户的id 键值是用户的昵称nickname。
// 获取所有用户的ID和昵称列表示例:如果傳入多个字段的名称例如:
它返回的是一个二维数组,类似select方法的返回结果区别的是这个二维数组的键名是用户的id(准确的说是:getField方法的第一个字段名)。
示例:如果我们传入一个字符串分隔符:
那么返回的结果就是一个数组键名是用户id,键值是 nickname:email的输出字符串
另外:sepa参数还可以支持限制数量,可以配合使用order方法使用例如:
在关联查询时如果需要自定义field(仅显示自定义field),需要增加 removeOption('field') 对字段进行清空
如果清空会造成的影响:
1、除了自定义的字段以外,还会显示主表字段信息、关联表字段信息
* 设置关联查询JOIN预查询 // 支持闭包查询过滤关联条件
版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。