yii遍历行下的每列数据(小1月考)
效果图:

控制器(1种):
//显示列表
public function actionList()
{
//实例化对象
$model= new Qiu();
$country = \Yii::$app->db;
//查询数据
$data = $country->createCommand("select * from qiu join region on qiu.region_id=region.region_id")->queryAll();
$region_ids = $country->createCommand("select region_id from region")->queryAll();
$region = $country->createCommand("select * from region")->queryAll();
//遍历数组
$ids = array();
$names = array();
$count = array();
//遍历区域ID
foreach ($region_ids as $key => $v)
{
$ids[$key] = $v['region_id'];
}
//print_r($ids);die;
//遍历球队
foreach ($ids as $key => $val)
{
$data =Qiu::find()->where(['region_id'=>$val])->asArray()->all();
$count[]=count($data);
$rows[$val] = $data;
}
//print_r($rows);die;
//根据所有记录进行遍历,显示最多行数
$ji = max($count);
$arr = array();
//找出对应的球队
for($i=0;$i<$ji;$i++)
{
foreach($rows as $key => $val)
{
if(isset($val[$i]))
{
$arr[$i][$key] = $val[$i]['q_name'];
}
else
{
$arr[$i][$key] = '';
}
}
}
//var_dump($arr);die;
//分配数据
return $this->render('list',['arr'=>$arr,'region'=>$region]);
}
(2种):
public function actionList1()
{
//实例化模型层
$region = new Region;
$qiu = new Qiu;
//取出区域表的iQiud和所有数据,队表数据
$region_ids = $region->find()->select('region_id')->column();
$areas = $region->find()->asArray()->all();
$team = $qiu->find()->asArray()->all();
$count = array();
$info = array();
foreach ($region_ids as $aid) {//1,2,3--6
foreach ($team as $key=>$val) {
if($val['region_id'] == $aid){
$info[$aid][] = $val;
$count[]=count($info[$aid]);
}
}
}
//var_dump($count);die;
$con = max($count);
$arr = array();
for ($i=0; $i <$con ; $i++) {
foreach ($info as $key => $val) {
if(isset($val[$i])){
$arr[$i][$key] = $val[$i]['q_name'];
} else {
$arr[$i][$key] = '';
}
}
}
//var_dump($arr);die;
return $this->render('list',['arr'=>$arr,'region'=>$areas]);
}
视图层:
<table border="1">
<!--一行区域-->
<tr style="background:red;">
<?php foreach ($region as $key => $v1) {?>
<td><?php echo $v1['region_name']; ?></td>
<?php }?>
</tr>
<!--每列球队-->
<?php foreach ($arr as $key => $val) {?>
<tr>
<?php foreach ($val as $key => $v) {?>
<td><?php echo $v; ?></td>
<?php } ?>
</tr>
<?php } ?>
</table>
yii遍历行下的每列数据(小1月考)的更多相关文章
- DataTable相关操作,筛选,取前N条数据,去重复行,获取指定列数据
#region DataTable筛选,排序返回符合条件行组成的新DataTable或直接用DefaultView按条件返回 /// <summary> /// Dat ...
- kendo ui grid控件在选择行时如何取得所选行的某一列数据
$("#grid").kendoGrid({ dataSource: dataSrc, columns: [ { template: '#=material_id#', width ...
- Excel 一张表最多能装下多少行多少列数据?
一个工作簿可以装下255张,那么每张工作表可以装下多少行多少列数据呢? 1.任意打开或新建一个Excel文档. 2.在文档中,找到其左上角的"文件"按钮,点击选择"选项& ...
- C/C++遍历二维数组,列优先(column-major)比行优先(row-major)慢,why?
C/C++遍历二维数组,列优先(column-major)比行优先(row-major)慢,why? 简单粗暴的答案:存在Cache机制! 稍微啰嗦一点:CPU访问内存(读/写,遍历数组的话主要是读) ...
- 【面试总结-编程】多行两列数据,实现同key的value求和并输出
一个文件,两列,多行. 第一列是字母,第二列是数字,同列数据之间通过空格分割. 统计首列字母相同的第二列之和. 样例输入: A 5 B 6 OO 7 A 6 A 2 OO 2 输出: A:13 B:6 ...
- Python学习随笔:使用xlwings设置和操作excel多行多列数据以及设置数据字体颜色填充色对齐方式的方法
☞ ░ 前往老猿Python博文目录 ░ 在前面老猿的文章中,<Python学习随笔:使用xlwings读取和操作Excel文件>.<Python学习随笔:使用xlwings读取和操 ...
- FPGA计算3行同列数据之和
实验:FPGA计算3行同列数据之和 实验要求:PC机通过串口发送3行数据(一行有56个数据,3行共有56*3=168个数据)给FPGA,FPGA计算3行同一列数据的和,并将结果通过串口返回给上位机. ...
- SQL两列数据,行转列
SQL中只有两列数据(字段1,字段2),将其相同字段1的行转列 转换前: 转换后: --测试数据 if not object_id(N'Tempdb..#T') is null drop table ...
- 视图合并、hash join连接列数据分布不均匀引发的惨案
表大小 SQL> select count(*) from agent.TB_AGENT_INFO; COUNT(*) ---------- 1751 SQL> select count( ...
随机推荐
- JavaScript中的prototype
关于prototype: 理解prototype不应把它和继承混淆.A的prototype为B的一个实例,可以理解A将B中的方法和属性全部克隆了一遍.A能使用B的方法和属性.这里强调的是克隆而不是继承 ...
- VB动态添加WebBrowser控件,并拦截弹出窗口(不用引用任何组件)
新建空白窗体,然后粘帖下面代码: Option ExplicitPublic WithEvents br As VBControlExtender Private Sub br_ObjectEvent ...
- sqlserver 通过convert取得指定格式的时间
http://msdn.microsoft.com/zh-cn/library/ms187928(v=sql.105).aspx CONVERT(NVARCHAR(10),Created,112) 不 ...
- 在RHEL5.2 64bit下编译安装log4cxx错误
apache-log4cxx.0.10.0 依赖于apache-apr和apache-apr-utils两个包 先安装他们俩,然后编译log4cxx,发现make失败,错误如下 ronized.o . ...
- imx6 u-boot.bin 和 u-boot.imx
有些MFG TOOL烧录工具使用了u-boot.imx,而不是原来的u-boot.bin文件进行烧录. 这两个镜像的区别是,u-boot.bin文件编译后,会在u-boot.bin的开头添加一个大小为 ...
- linux matlab2013b 安装教程
链接:http://pan.baidu.com/s/1pJE6R2b 密码:shfy 1. 解压缩“Mathworks Matlab R2013b Linux.rar”(无需密码),得到“Mathwo ...
- 将option添加到select框
var select=document.createElement("select"); select.setAttribute("class","f ...
- Oracle中的数据类型和数据类型之间的转换
Oracle中的数据类型 /* ORACLE 中的数据类型: char 长度固定 范围:1-2000 VARCHAR2 长度可变 范围:1-4000 LONG 长度可变 最大的范围2gb 长字符类型 ...
- iOS:抽屉侧滑动画两种形式(1、UIView侧滑 2、ViewController侧滑)
前言: 在iOS中抽屉动画是很常用的一种技术,使用它有很炫的体验效果,为app增添特色,形式就两种,一个是UIView的侧滑,另一个就是ViewController的侧滑. 实现方式: 抽屉侧滑动画有 ...
- nginx 414 Request-URI Too Large
症状 nginx 414 Request-URI Too Large #客户端请求头缓冲区大小,如果请求头总长度大于小于128k,则使用此缓冲区, #请求头总长度大于128k时使用large_clie ...