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 ...
随机推荐
- 防止IE不支持console.log报错
function log(msg){ if (window["console"]){//判断是否是IE console.log(msg); } }
- 修改最大打开文件数和最大proc数量
1.vim /etc/profile 增加 ulimit -n 10240 ulimit -u 10240 2.修改/etc/security/limits.conf * soft ...
- MySQL半同步复制的安装和配置
(1)检查master/slave是否支持动态加载插件 > show variables like 'have_dynamic_loading'; +---------------------- ...
- java Double封装类的对象保留两位小数
double value = 22.365454; DecimalFormat df = new DecimalFormat("##.00");value = Double.par ...
- Swift游戏实战-跑酷熊猫 04 熊猫的跳和滚的动作
这节内容,我们利用上一节学过的内容,给熊猫添加跳和滚动的动作.同时通过重载touchBegan方法来响应动作.切换跑,跳,滚. 要点: 通过序列帧纹理产生动画: SKAction.animatWith ...
- [原创]java WEB学习笔记69:Struts2 学习之路-- 消息处理与国际化,概述,配置国际资源文件,访问国际化消息,通过超链接切换语言
本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...
- Python学习总结16:时间模块datetime & time & calendar (三)
calendar模块 常见函数及说明 1 calendar.calendar(year,w=2,l=1,c=6) 返回一个多行字符串格式的year年年历,3个月一行,间隔距离为c. 每日宽度间隔为 ...
- checkbox的相关知识点
1.获取单个checkbox选中项(三种写法)$("input:checkbox:checked").val()或者$("input:[type='checkbox']: ...
- Android -- 背景虚化
1,在项目中我们常有这样的需求,就是在个人中心的时候,当用户登录后,要显示用户登陆后的头像,然后背景是用户头像的虚化 ,接下来就来实现一下这个功能,先看一下效果 2,实现起来也挺简单的,没什么难度 , ...
- 【python】python环境的安装与配置
安装配置pip / easy_install / virtualenv 在ubuntu 10.10之后的版本中,要这样安装 sudo apt-get install python-pip python ...