3

我正在为过去几天一直困扰我的 SQL 查询而苦苦挣扎。我希望你们能帮助我!

我将为购物车创建发票。发票保存在两个表中。第一个表“ordre”包含有关用户的信息,发票是否已支付以及日期等。第二个表“ordreelementer”包含属于该发票的所有项目。

我的问题来了。我到底如何获得打印包含客户详细信息的发票所需的所有信息,以及他/她购买的物品?我尝试了不同的 SQL JOINS,但没有按预期工作。这里的任何帮助将不胜感激!我正在编写 PHP 并运行 MySQL 数据库。

这是我最新的 SQL 语句

$sql = "SELECT ordre.id, 
               ordre.uid, 
               ordre.dato, 
               ordre.status, 
               ordre.betalt, 
               ordre.navn, 
               ordre.adresse, 
               ordreelementer.oid,
               ordreelementer.navn AS elnavn,  
               SUM(ordreelementer.ant * ordreelementer.stkpris) AS tot
          FROM ordre 
          INNER JOIN ordreelementer 
               ON ordre.id=ordreelementer.oid 
          WHERE ordre.uid = ".brukerInfo('id')." AND ordre.id = ".$id."";

非常感谢所有帮助!

4

3 回答 3

1

这将为您提供总订单的总和,并且您的订单元素将以逗号分隔值的形式出现。

SELECT ordre.id, 
           ordre.uid, 
           ordre.dato, 
           ordre.status, 
           ordre.betalt, 
           ordre.navn, 
           ordre.adresse, 
           ordre.id,
           GROUP_CONCAT(ordreelementer.navn) AS elnavn,  
           SUM(ordreelementer.ant * ordreelementer.stkpris) AS tot
      FROM ordre 
      INNER JOIN ordreelementer 
           ON ordre.id=ordreelementer.oid 
      WHERE ordre.uid = ".brukerInfo('id')." AND ordre.id = ".$id.""
      GROUP BY ordre.id;

或者,您可以按订单元素 ID 对其进行分组,并使用 WITH ROLLUP 选项。这将为您提供每个元素的单独记录,并在最后为您生成总计行。

SELECT ordre.id, 
       ordre.uid, 
       ordre.dato, 
       ordre.status, 
       ordre.betalt, 
       ordre.navn, 
       ordre.adresse, 
       ordreelementer.oid,
       ordreelementer.navn AS elnavn,  
       SUM(ordreelementer.ant * ordreelementer.stkpris) AS eltot
  FROM ordre 
  INNER JOIN ordreelementer 
       ON ordre.id=ordreelementer.oid 
  WHERE ordre.uid = ".brukerInfo('id')." AND ordre.id = ".$id.""
  GROUP BY ordereelementer.id WITH ROLLUP;

最后一个分组是一个伪组,因为每个组只有一个元素项。

于 2013-09-12T20:49:07.027 回答
0
$sql = "SELECT ordre.id, 
               ordre.uid, 
               ordre.dato, 
               ordre.status, 
               ordre.betalt, 
               ordre.navn, 
               ordre.adresse, 
               ordreelementer.oid,
               ordreelementer.navn AS elnavn,  
               ordreelementer.ant as val1,
               ordreelementer.stkpris AS val2
          FROM ordre 
          INNER JOIN ordreelementer 
               ON ordre.id=ordreelementer.oid 
          WHERE ordre.uid = ".brukerInfo('id')." AND ordre.id = ".$id."";

此查询返回所有值。现在,当您通过循环生成发票时,您必须计算总价值。

于 2013-09-12T20:41:56.553 回答
0

由于您只是填写发票,我的想法是将这个查询分解为几个查询,除非您出于某种原因需要它成为一个查询,无论是纯粹的还是实用的。这将使您避免ordre在结果集的每一行上出现所有这些信息的重复数据。无论如何,为了让您下班并运行和打印发票,以下应该可以工作。

首先,从表中拉取你只需要一行的数据ordre,也就是你的基本订单信息:

$sqlOrdreInfo = "SELECT ordre.id, 
                        ordre.uid, 
                        ordre.dato, 
                        ordre.status, 
                        ordre.betalt, 
                        ordre.navn, 
                        ordre.adresse
                FROM ordre 
                WHERE ordre.uid = ".brukerInfo('id')." AND ordre.id = '.$id.'";

二、拉单个订单线:

$sqlOrdreLines = "SELECT ordreelementer.oid,
                         ordreelementer.navn AS elnavn
                  FROM ordreelementer 
                  WHERE  ordreelementer.oid = '.$id.'";

第三,提取您想要的总和:

$sqlOrdreTotal = "SELECT SUM(ordreelementer.ant * ordreelementer.stkpris) AS tot
                  FROM ordreelementer 
                  WHERE  ordreelementer.oid = '$id.'
                  GROUP BY ordreelementer.oid";

这将为您提供 3 个结果集,您可以轻松地在发票上打印所需的数据。

于 2013-09-12T20:36:03.493 回答