1

如何返回 provision_id 列的结果,以便它们以每行的contracts.id 为条件?现在,我在每一行都得到相同的结果。想要的效果有点像 Excel 中的 VLookup。不确定如何使用 if else/sql 值在 PHP 中实现它。

相关代码:

<?php
global $wpdb;
$contents = $wpdb->get_results( $wpdb->prepare("SELECT id, name, remaining, contract_value FROM salaries"));
$contracts = $wpdb->get_results( $wpdb->prepare("SELECT contracts.id,source,provision,provision_id FROM contracts LEFT JOIN salaries ON contracts.id = salaries.id"));

 ?>

   [table header stuff...]

foreach ($contents as $content) {
    ?>   
         <tr>
                <td><?php echo $content->name ?></td>
                <td><?php echo $content->remaining ?></td>
                <td><?php echo $content->contract_value ?></td>
                <td><?php foreach ($contracts as $contract) { echo $contract->provision_id }; ?> 
               </td>

电流输出

Name               Remaining         Contract_Value    Provision_ID
--------------     ---------------   --------------    --------------
Adam               100               300               A1 B1 C1
Bill               200               400               A1 B1 C1
Chad               200               400               A1 B1 C1

期望的输出

Name               Remaining         Contract_Value    Provision_ID
--------------     ---------------   --------------    --------------
Adam               100               300               A1
Bill               200               400               B1
Chad               200               400               C1

其中 A1,B1,C1 分别代表一个存储的数据单元格,该单元格对应于 column1 中的人名。我试图根据 Adam、Bill 和 Chad 的 ID 而不是名称来设置 provision_id 条件,但我不希望 ID 显示在 php 输出中。

本质上,我希望 PHP “查找” ID(又名成员 ID)并打印相应的 provision_id。在这种情况下,连接表格可能不起作用,因为我还从表格中拉出“工具提示”作为 A1、B1、C1 等的鼠标悬停效果。

附录 1 - 也就是正在发生的事情。我没有解释(为了保持简单)亚当比尔和乍得每个人都有不止一个供应 ID。Adam 有供应 ID:例如 A1、A2 和 A3。我试图避免下面的问题(GROUP_CONCAT 可以工作,但我不认为它可以,因为我对每个条款都有一个鼠标悬停工具提示)。

Name               Remaining         Contract_Value    Provision_ID
--------------     ---------------   --------------    --------------
Adam               100               300               A1
Adam               100               300               A2
Adam               100               300               A3
Bill               200               400               B1
Bill               200               400               B2
Chad               200               400               C1
4

2 回答 2

1

尝试以下查询。然后,您可以通过对数据库的一个请求来完成所有操作。

SELECT salaries.id AS salaries_id, salaries.name, salaries.remaining, 
salaries.contract_value, contracts.provision_id AS provision_id 
FROM salaries LEFT JOIN contracts ON contracts.id=salaries.id
于 2009-07-20T18:28:42.753 回答
0

不得不为此寻求专业帮助,因为我仍在自学。他使用了一种称为条件简写的技术,使得 $contracts 查询只对两个表之间 'id' 匹配的行起作用。

获奖代码片段:

     foreach ($contracts as $contract)
                    {
                        echo ( $content->id == $contract->id ) ?
                             '<a href="' . $contract->source . '" tooltip="' . $contract->provision . '">' . $contract->provision_id . " " . '</a>' : '';
                     } 
                   ?>
                </td>

<?php };

他给我发了这个链接:http ://www.bradino.com/php/ternary-operator-conditional/ 你可以在http://travisballard.com/找到他。

干杯!

于 2009-07-20T22:27:20.167 回答