PHP多表取数据的代码优化
<?php
header("Content-type: text/html; charset=utf-8");
//假设这里的$goods_arr 和 $shop_arr 都是从数据库中查询出来的数组
$goods_arr = array(
0 => array(
'activity_id' => 1,
'activity_name' => '午夜今日特价345345sss',
'shop_id' => 300001,
),
1 => array(
'activity_id' => 2,
'activity_name' => '0点档限量抢购',
'shop_id' => 300002,
),
2 => array(
'activity_id' => 3,
'activity_name' => '凌晨惊爆抢购',
'shop_id' => 300003,
),
3 => array(
'activity_id' => 4,
'activity_name' => '午夜限时抢购',
'shop_id' => 300003,
'create_time' => 1395050666,
'update_time' => 1411887987,
'is_del' => 1,
),
4 => array(
'activity_id' => 5,
'activity_name' => '早场限量秒杀',
'shop_id' => 300001,
),
5 => array(
'activity_id' => 6,
'activity_name' => '9点底价抢购',
'shop_id' => 300002,
)
);
$shop_arr = array(
0 => array(
'shop_id' => 300001,
'shop_name' => '一号店',
),
1 => array(
'shop_id' => 300002,
'shop_name' => '天猫商城',
),
2 => array(
'shop_id' => 300003,
'shop_name' => '京东',
),
3 => array(
'shop_id' => 300004,
'shop_name' => '当当网',
)
);
//传统做法,需要循环查询 tbShop表 的 次数就是 count($goods_arr)
foreach($goods_arr as $k=>$v){
$goods_arr[$k]['shop_name'] = "select shop_name from tbShop where shop_id = $v[shop_id]";//这里只是SQL语句,能够表达意思即可。
}
//重点开始....................
$temp = array();
foreach($shop_arr as $val){
$temp[$val['shop_id']] = $val;
}
//通过引用传递 &$v 将key "shop_name" 付给 $goods_arr [精辟]
foreach($goods_arr as &$v){
$shop_id=$v['shop_id'];
$v['shop_name']= $temp[$shop_id]['shop_name'];
}
print_r($goods_arr);
/**
//最后结果
Array
(
[0] => Array
(
[activity_id] => 1
[activity_name] => 午夜今日特价345345sss
[shop_id] => 300001
[shop_name] => 一号店
)
[1] => Array
(
[activity_id] => 2
[activity_name] => 0点档限量抢购
[shop_id] => 300002
[shop_name] => 天猫商城
)
[2] => Array
(
[activity_id] => 3
[activity_name] => 凌晨惊爆抢购
[shop_id] => 300003
[shop_name] => 京东
)
[3] => Array
(
[activity_id] => 4
[activity_name] => 午夜限时抢购
[shop_id] => 300003
[create_time] => 1395050666
[update_time] => 1411887987
[is_del] => 1
[shop_name] => 京东
)
[4] => Array
(
[activity_id] => 5
[activity_name] => 早场限量秒杀
[shop_id] => 300001
[shop_name] => 一号店
)
[5] => Array
(
[activity_id] => 6
[activity_name] => 9点底价抢购
[shop_id] => 300002
[shop_name] => 天猫商城
)
)
*/
?>
PHP多表取数据的代码优化的更多相关文章
- Drf 序列化 ModelSerializer跨表取数据
1.对于OneToOne.Foreignkey.choices字段可以使用source取出相关信息: class CourseSerializer(serializers.ModelSerialize ...
- 定时从远程的数据库中取数据,然后把取出来的数据插入或更新本地的oracle数据库的表
最近项目中有一种需求: 大致需求是这样的 通过给定的 用户名和密码 要定时从远程的数据库中取数据,然后把取出来的数据插入或更新本地的oracle数据库的表 项目的结构式struts1 hibernat ...
- Oracle 取两个表中数据的交集并集差异集合
Oracle 取两个表中数据的交集 关键字: Oracle 取两个表中数据的交集 INTERSECT Oracle 作为一个大型的关系数据库,日常应用中往往需要提取两个表的交集数据 例如现有如下表,要 ...
- 组件 layui 表单抓取数据四步走
注意事项: layui 中提交按钮是基于"监听"机制实现的. form.on() 的调用需置于 layui.use 的回调函数中. 末尾的 'return false' 不可或缺, ...
- 部分真验货客户未取进FP IN_SALES_ORDER表有数据,前台规划页面没显示
描述:部分真验货客户未取进FP,检查发现IN_SALES_ORDER表有数据630\600\610行项目数据,但前台只显示630数据,600和610前台没有显示 1.查看IN_SALES_ORDER表 ...
- 简单又强大的pandas爬虫 利用pandas库的read_html()方法爬取网页表格型数据
文章目录 一.简介 二.原理 三.爬取实战 实例1 实例2 一.简介 一般的爬虫套路无非是发送请求.获取响应.解析网页.提取数据.保存数据等步骤.构造请求主要用到requests库,定位提取数据用的比 ...
- EF里单个实体的增查改删以及主从表关联数据的各种增删 改查
本文目录 EF对单个实体的增查改删 增加单个实体 查询单个实体 修改单个实体 删除单个实体 EF里主从表关联数据的各种增删改查 增加(增加从表数据.增加主从表数据) 查询(根据主表找从表数据.根据从表 ...
- MySQL单表百万数据记录分页性能优化
背景: 自己的一个网站,由于单表的数据记录高达了一百万条,造成数据访问很慢,Google分析的后台经常报告超时,尤其是页码大的页面更是慢的不行. 测试环境: 先让我们熟悉下基本的sql语句,来查看下我 ...
- EF如何操作内存中的数据以及加载相关联表的数据:延迟加载、贪婪加载、显示加载
之前的EF Code First系列讲了那么多如何配置实体和数据库表的关系,显然配置只是辅助,使用EF操作数据库才是每天开发中都需要用的,这个系列讲讲如何使用EF操作数据库.老版本的EF主要是通过Ob ...
随机推荐
- Android系统自带样式(@android:style/)
在AndroidManifest.xml文件的activity中配置 1.android:theme="@android:style/Theme" 默认状态,即如果theme这里不 ...
- 网页flv下载探索_1
最近看了一个优酷视频(非优酷网站,最终地址指向优酷),用chrome开发者工具,可找到flv地址如下,简单摘录如下: http://27.221.100.104/657D4D2878C3382C781 ...
- 第九篇 Replication:复制监视器
本篇文章是SQL Server Replication系列的第九篇,详细内容请参考原文. 复制监视器允许你查看复制配置组件的健康状况.这一篇假设你遵循前八篇,并且你已经有一个合并发布和事务发布.启动复 ...
- swift NSUserDefaults的基本使用
import UIKit @UIApplicationMain class AppDelegate: UIResponder, UIApplicationDelegate { var window: ...
- iOS 图片实现马赛克效果
/** *实现马赛克效果 */ // 导出CIImage图片 CIImage *ciImage = [[CIImage alloc] initWithImage:[UIImageimageNamed: ...
- 深入理解CSS3 Animation 帧动画 ( steps )
作者:Aaron的博客 网址:http://www.cnblogs.com/aaronjs/p/4642015.html --------------------------------------- ...
- WPF 基础面试题及答案(一)
一 · WPF由哪两部分组成? wpf 由两个主要部分 组成:引擎和编程框架. 1 引擎.wpf引擎是基于窗体的应用程序 图形 视频 音频和文档提供了一个单一的运行时库.重要的是WPF基于矢量的呈现引 ...
- FB面经prepare: Task Schedule
每种task都有冷却时间,比如task1执行后,要经过interval时间后才能再次执行,求总共所需时间. 用HashMap保存每一个task的下一次可以开始执行的最早时间 package TaskS ...
- SQL top order between 一起使用
select * from emp;
- cell点击按钮崩的一种情况
这个错误表示:该类方法没有addBtnClick对应的方法: bug的复现:创建一个cell,并且添加一个类方法来赋值,在方法中,给按钮添加一个点击事件(addBtnClick),但是,再实现这个方法 ...