<?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多表取数据的代码优化的更多相关文章

  1. Drf 序列化 ModelSerializer跨表取数据

    1.对于OneToOne.Foreignkey.choices字段可以使用source取出相关信息: class CourseSerializer(serializers.ModelSerialize ...

  2. 定时从远程的数据库中取数据,然后把取出来的数据插入或更新本地的oracle数据库的表

    最近项目中有一种需求: 大致需求是这样的 通过给定的 用户名和密码 要定时从远程的数据库中取数据,然后把取出来的数据插入或更新本地的oracle数据库的表 项目的结构式struts1 hibernat ...

  3. Oracle 取两个表中数据的交集并集差异集合

    Oracle 取两个表中数据的交集 关键字: Oracle 取两个表中数据的交集 INTERSECT Oracle 作为一个大型的关系数据库,日常应用中往往需要提取两个表的交集数据 例如现有如下表,要 ...

  4. 组件 layui 表单抓取数据四步走

    注意事项: layui 中提交按钮是基于"监听"机制实现的. form.on() 的调用需置于 layui.use 的回调函数中. 末尾的 'return false' 不可或缺, ...

  5. 部分真验货客户未取进FP IN_SALES_ORDER表有数据,前台规划页面没显示

    描述:部分真验货客户未取进FP,检查发现IN_SALES_ORDER表有数据630\600\610行项目数据,但前台只显示630数据,600和610前台没有显示 1.查看IN_SALES_ORDER表 ...

  6. 简单又强大的pandas爬虫 利用pandas库的read_html()方法爬取网页表格型数据

    文章目录 一.简介 二.原理 三.爬取实战 实例1 实例2 一.简介 一般的爬虫套路无非是发送请求.获取响应.解析网页.提取数据.保存数据等步骤.构造请求主要用到requests库,定位提取数据用的比 ...

  7. EF里单个实体的增查改删以及主从表关联数据的各种增删 改查

    本文目录 EF对单个实体的增查改删 增加单个实体 查询单个实体 修改单个实体 删除单个实体 EF里主从表关联数据的各种增删改查 增加(增加从表数据.增加主从表数据) 查询(根据主表找从表数据.根据从表 ...

  8. MySQL单表百万数据记录分页性能优化

    背景: 自己的一个网站,由于单表的数据记录高达了一百万条,造成数据访问很慢,Google分析的后台经常报告超时,尤其是页码大的页面更是慢的不行. 测试环境: 先让我们熟悉下基本的sql语句,来查看下我 ...

  9. EF如何操作内存中的数据以及加载相关联表的数据:延迟加载、贪婪加载、显示加载

    之前的EF Code First系列讲了那么多如何配置实体和数据库表的关系,显然配置只是辅助,使用EF操作数据库才是每天开发中都需要用的,这个系列讲讲如何使用EF操作数据库.老版本的EF主要是通过Ob ...

随机推荐

  1. jquery在线预览PDF文件,打开PDF文件(向下兼容ie8、ie7)

    最主要的是使用到了一个jquery的插件jquery.media.js,使用这个插件就很容易实现了. 核心代码 <!DOCTYPE html PUBLIC "-//W3C//DTD X ...

  2. HTML页面刷新、跳转

    HTML方式 1.页面刷新 <!-- 5秒之后,跳转到http://www.qunar.com页面 --> <meta http-equiv="refresh" ...

  3. 11G中自动收集统计信息

    在11G中,引入了一个名为 gather_stats_prog 的自动运行任务专用于自动收集统计信息.其对应的客户端名称为"auto optimizer stats collection&q ...

  4. cache与SDRAM

    hugohong hugohong 本版等级:   #2 得分:20回复于: 2009-04-19 21:51:03 牛人说的,拿出来分享一下:cache是高速缓冲, 解决高速cpu和相对低速sdra ...

  5. BenchmarkSQL测试脚本实现

    sqlTableCreates DROP SCHEMA IF EXISTS benchmarksql CASCADE; CREATE SCHEMA benchmarksql; create table ...

  6. DIY小能手|别买电动滑板车了,咱做一台吧

    !! http://www.shoudian.org/thread-316111-1-1.html http://www.jiequer.com/html/news/xinpin/2014/1218/ ...

  7. Python学习总结13:os模块

    os模块包含普遍的操作系统功能,与具体的平台无关.常用于处理文件和目录这些我们日常手动需要做的操作. 1. os模块函数汇总 1) os.name():判断现在正在实用的平台,Windows 返回 ‘ ...

  8. MyEclipse下如何安装和使用ibatis插件(网上的资料对于myeclipse8.5根本就是没有用的,所以我还是自己选择了装了一个eclipse,然后将插件装在了eclipse中)

    (1)myeclipse→help→Myeclipse configuration center:点击sofeware选项卡,在Browes Software 下有一个输入框,点击add site按钮 ...

  9. 今天遇到的一个问题(windows的ssh客户端连接不到虚拟机Ubuntu)

    今天比较郁闷,想用windows上的ssh客户端连接虚拟机中的Ubuntu. 但是死活连不上,之前是能脸上的,所以比较郁闷. 我首先在windows上ping Ubuntu的ip地址,竟然发不了数据包 ...

  10. linux第2天 信号 wait

    孤儿进程和僵尸进程 如果父进程先退出,子进程还没退出那么子进程的父进程将变为init进程.(注:任何一个进程都必须有父进程) 如果子进程先退出,父进程还没退出,那么子进程必须等到父进程捕获到了子进程的 ...