目录

新手模式

用上次的查询结果,作为本次的查询条件

    //关联查询
public function actionRelatesearch(){
//新手模式
$category = Category::findOne(2); //查分类表里的数据 abj
$categoryarr = $category->attributes; //获取某一行的分类结果里的对象属性,array
dump($categoryarr); //查文章里的cid等于2的 拿上面的结果 $categoryarr['cid']=2 作为本次查询的条件
$article = Article::find()->asArray()->where(['cid'=>$categoryarr['cid']])->all();
dump($article); //返回的是二维数组arr
}

结果:

Array
(
[cid] => 2
[c_name] => 娱乐
) Array
(
[0] => Array
(
[article_id] => 6
[article_title] => php的发展前景怎样
[num] => 8
[cid] => 2
) [1] => Array
(
[article_id] => 7
[article_title] => 67岁宋春丽与聂远出新戏,满头花发让人心疼,面容慈祥豪爽依旧!
[num] => 12
[cid] => 2
) [2] => Array
(
[article_id] => 8
[article_title] => 知微又涨粉啦!《天盛长歌》小衣衣、楚王和金狮王子你会选谁?
[num] => 18
[cid] => 2
) [3] => Array
(
[article_id] => 9
[article_title] => 刘亦菲穿旗袍带仙气,赵丽颖穿旗袍优雅,她穿旗袍最有民国范
[num] => 14
[cid] => 2
) )

hasMany关联模式查询

思路

1.用category表里查一行,查出某一个分类下的所有字段 结果是一维数组下的值是obj

2.查出来的结果,用hasMany()去关联查询article表里的关联字段cate_id查询出属于该分类下的所有数据,用all()方法查多行

新建mode层Article.php

<?php
namespace app\models; use yii\db\ActiveRecord; class Article extends ActiveRecord
{ }

新建mode层Category.php

<?php
namespace app\models; use yii\db\ActiveRecord; class Category extends ActiveRecord
{ }

新建控制器HomeController.php

    public function actionRelatesearch(){
//关联查询
//查询方法一(查一行) 一维数组下的值是obj
// $category = Category::findOne(1); //查分类表里的数据 abj
//// vp($category);
// $articles = $category->hasMany(Article::className(),['cate_id'=>'cid'])->asArray()->all();
// dd($articles); //查询方法二(查多行,结果需要提出一行来使用):
//查分类表里的数据要是一维数组下的值是obj 不能用asArray()转为数组,不然hasMany会报错
$category = Category::find()->where(['cid'=>2])->all();
vp($category);
//关联查询 用hasMany方法前提要满足二个条件
//1.如果查出来是二维数组需要用角标提成一维数组
//2.主表category 表查出来的结果要是一维数组下的值是obj 不能用asArray转成数组
//第一个参数是string article的命名空间app/models/Article == Article::className()
vp(Article::className()); //打印结果app/models/Article
//第二个参数是array key是article表里的关联字段 value是category里的主键
$articles = $category[0]->hasMany(Article::className(),['cate_id'=>'cid'])->asArray()->all();
dd($articles);
}

打印结果

D:\xampp\htdocs\yii\helper\function.php:19:
array (size=1)
0 =>
object(app\models\Category)[78]
private '_attributes' (yii\db\BaseActiveRecord) =>
array (size=2)
'cid' => string '2' (length=1)
'c_name' => string '娱乐' (length=6)
private '_oldAttributes' (yii\db\BaseActiveRecord) =>
array (size=2)
'cid' => string '2' (length=1)
'c_name' => string '娱乐' (length=6)
private '_related' (yii\db\BaseActiveRecord) =>
array (size=0)
empty
private '_relationsDependencies' (yii\db\BaseActiveRecord) =>
array (size=0)
empty
private '_errors' (yii\base\Model) => null
private '_validators' (yii\base\Model) => null
private '_scenario' (yii\base\Model) => string 'default' (length=7)
private '_events' (yii\base\Component) =>
array (size=0)
empty
private '_eventWildcards' (yii\base\Component) =>
array (size=0)
empty
private '_behaviors' (yii\base\Component) =>
array (size=0)
empty D:\xampp\htdocs\yii\helper\function.php:19:string 'app\models\Article' (length=18) D:\xampp\htdocs\yii\helper\function.php:26:
array (size=4)
0 =>
array (size=4)
'article_id' => string '6' (length=1)
'article_title' => string 'php的发展前景怎样' (length=24)
'num' => string '8' (length=1)
'cate_id' => string '2' (length=1)
1 =>
array (size=4)
'article_id' => string '7' (length=1)
'article_title' => string '67岁宋春丽与聂远出新戏,满头花发让人心疼,面容慈祥豪爽依旧!' (length=89)
'num' => string '12' (length=2)
'cate_id' => string '2' (length=1)
2 =>
array (size=4)
'article_id' => string '8' (length=1)
'article_title' => string '知微又涨粉啦!《天盛长歌》小衣衣、楚王和金狮王子你会选谁?' (length=87)
'num' => string '18' (length=2)
'cate_id' => string '2' (length=1)
3 =>
array (size=4)
'article_id' => string '9' (length=1)
'article_title' => string '刘亦菲穿旗袍带仙气,赵丽颖穿旗袍优雅,她穿旗袍最有民国范' (length=84)
'num' => string '14' (length=2)
'cate_id' => string '2' (length=1)

20.Yii2.0框架多表关联一对多查询之hasMany的更多相关文章

  1. 21.Yii2.0框架多表关联一对多查询之性能优化--模型的使用

    控制器里 功能: 通过分类,查分类下的所有文章 //关联查询 public function actionRelatesearch(){ //关联查询 //查询方法一(查一行) 一维数组下的值是obj ...

  2. 22.Yii2.0框架多表关联一对一查询之hasOne

    思路: 通过文章查它对应的分类信息 一对一的关系 控制器里 //一对一关联查询 public function actionRelatesone() { //方法一,hasOne() 用查一条文章的结 ...

  3. Mybatis表关联一对多、多对一、多对多

    项目工程结构如下: 1. 搭建MyBatis框架环境 首先需要引入两个包:mybatis.jar 和 sqljdbc42.jar包 若分页需要导入两个包:pagehelper-5.1.0.jar 和 ...

  4. 后盾网lavarel视频项目---lavarel多表关联一对多操作实例

    后盾网lavarel视频项目---lavarel多表关联一对多操作实例 一.总结 一句话总结: 1.一对多中多那个部分的数据前端通过json弄到服务器 2.所有通过一操作多的时候,都要用上模型中定义的 ...

  5. yii2.0框架安装心得

    yii2.0安装心得 能够搜索到这篇文章的朋友相信是对yii框架有兴趣的,但是我不得不吐槽的是,这个安装过程确实让人头疼,接下来就让大家见证一下这个纠结的过程 根据官网的说法,安装这个框架需要用到co ...

  6. 8.Yii2.0框架控制器接收get.post数据

    8.Yii2.0框架控制器接收get.post数据 一.get传参 <?php /** * Created by Haima. * Author:Haima * QQ:228654416 * D ...

  7. 将一个多表关联的条件查询中的多表通过 create select 转化成一张单表的sql、改为会话级别临时表 【我】

    将一个多表关联的条件查询中的多表通过 create   select  转化成一张单表的sql 将结果改为创建一个会话级别的临时表: -- 根据下面这两个sql CREATE TABLE revenu ...

  8. Mybatis表关联一对多

    有了前面几章的基础,对一些简单的应用是可以处理的,但在实际项目中,经常是关联表的查询,比如:最常见到的多对一,一对多等.这些查询是如何处理的呢,这一讲就讲这个问题.前面几篇教程中介绍的都是单表映射的一 ...

  9. YII2.0使用ActiveForm表单(转)

    Controller控制器层代码 <?php namespace frontend\controllers; use frontend\models\UserForm; class UserCo ...

随机推荐

  1. shell中变量内容的删除,替代

    删除 ${varname#strMatch} // 在varname中从头匹配strMatch,然后删除从头到第一次匹配到的位置 ${varname##strMatch} // 在varname中从头 ...

  2. window.addeventlistener使用方法

    http://www.jb51.net/article/49858.htm .................................................... (要注意的是div ...

  3. Linux+.NetCore+Nginx

    Linux+.NetCore+Nginx搭建集群 本篇和大家分享的是Linux+NetCore+Nginx搭建负载集群,对于netcore2.0发布后,我一直在看官网的文档并学习,关注有哪些新增的东西 ...

  4. 转 DataGuard环境搭建 (一主一备一级联)

    DataGuard环境搭建 (一主一备一级联) http://blog.itpub.net/30130773/viewspace-2116985/ 1.--------- primary_role / ...

  5. c++11 右值的学习

    从4行代码看右值引用 概述 简单的左值和右值的判断就是  看是否可以取得地址   可取得地址 是左值     不能则  是右值! c++98/03中的左值引用是这样的: int i = 0; int& ...

  6. 075 Sort Colors 分类颜色

    给定一个包含红色.白色和蓝色,且含有 n 个元素的数组,对它们进行排序,使得相同颜色的元素相邻,颜色顺序为红色.白色.蓝色.此题中,我们使用整数 0, 1 和 2 分别表示红色,白色和蓝色.注意:不能 ...

  7. 从一个LocalDateTime引发的疑问

    一 公司有同事部署出错,然后查日志,找时间,从k8s得到的时间是  2017-06-16T09:38:48.580 +0000,然后他就纳闷了,因为他根本不会在9点部署好吧,而且9点大多数程序员都没开 ...

  8. 笔试题五道spring

    项目中如何体现Sping 中的切面编程,举例说明 面向切面编程:主要是横切 一个关注点,将一个关注点模块化成一个切面,在切面上声明一个通知(Advice)和切入点 (Pointcut) 通知:是指在切 ...

  9. 小米OJ刷题日志

    虽然这OJ上的题比较水,但还是挺有意思的.关键是能赚钱 特别是提交方式 居然不支持C++,垃圾OJ 4. 最长连续数列 排序后dp 5. 找出旋转有序数列的中间值 写个排序就做完了. 6. 交叉队列 ...

  10. JavaScript笔记6-数组新方法

    七.ECMAScript5关于数组的新方法 1.forEach():遍历数组,并为每个元素调用传入的函数;     举例:    var a = [1,2,3]; var sum = 0; //传一个 ...