duanliu6083 2014-09-17 19:00
浏览 7

在单个查询中使用2个表的方法

I had an assessment on pulling data from a table but i had to use two tables to do a calculation, i figured out a way to do it but it doesn't look good neither it would be good to keep using this way

        $query = mysqli_query($connection, "SELECT * FROM metal");
                $query2 = mysqli_query($connection, "SELECT * FROM conversion WHERE type = 'EUR'");
                $data2 = mysqli_fetch_array($query2);
                $query3 = mysqli_query($connection, "SELECT * FROM conversion WHERE type = 'USD'");
                $data3 = mysqli_fetch_array($query3);

                while($data = mysqli_fetch_array($query)){
                    echo "<tr>" . "<td>" . $data['metal'] . "</td>" . "<td>" . $data['cost'] . "</td>" . "<td>" . ($data['cost'] * $data3['amount']) . "</td>" . "</tr>";
                }

This grabs cost on metal type then using another table calculates cost in Euro and USD, I don't want to use 3 querys and fetch them 3 times as it isn't computationaly effective is there a better way to do it

  • 写回答

2条回答 默认 最新

  • duanjian7617 2014-09-17 19:03
    关注

    You'd need at least two, since you're fetching from two essentially unrelated tables

    SELECT * FROM metal
    SELECT * FROM conversion WHERE type IN ('EUR', 'USD')
    

    the second query will fetch BOTH records, and then you'll just need some extra code to sort out which record is which.

    评论

报告相同问题?

悬赏问题

  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?