0

你好,我在我的数据库中创建了 3 个表。

表 A = 分销商 A

表 B = 分销商 B

表 C = 分销商 C

每个表都使用来自每个分销商的以下字段进行更新。

Sku、价格、库存、产品名称、经销商名称

我现在要做的是创建一个新表,其中应该准备好导入的价格。

有以下规则:

如果库存 = 0 跳过

如果所有 3 个经销商表中都有相同的 sku,则采用最低价格并以最低价格更新。

所以我有一个包含以下内容的新表:

Sku、价格、库存、产品名称、经销商名称。

上表仅包含每个 sku 一次,并且总是最低价格与正库存。

任何人:-)

× 96472

225296

4

1 回答 1

0

您的问题不是最好的,我会尽力提供帮助,但更好的问题会得到更好的答案。

我假设您需要将表格保留为 3 个单独的表格(我个人不会,我只需添加一个distributor字段或类似的字段并将所有内容放在一个表格中)。

(从你的 PHP 标签来看,我会把它放在 php 中)。
我将提供一个相当具体的示例,但重要的是您要了解它是如何工作的,这样您才能适应它。

//Dist. A
$query = "SELECT * FROM `db`.`table_a` WHERE 1 ORDER BY `sku` DESC"; //Get the list of products
$result = mysql_query ($query) or die (mysql_error());
while ( $row = mysql_fetch_assoc($result)) {
  if ( $row['stock'] != 0 ) { //If we have stock...
    $query = "SELECT * FROM `final_table` WHERE `sku` LIKE '".$row['sku']."'"; //See if we have the data in the final table
    $final_result = mysql_query ($query) or die (mysql_error());
    if ( mysql_num_rows($final_result) == 0 ) { //Product Not in new table
      $query = "INSERT INTO `final_table` VALUES ( '".$row['sku']."' [The rest of your values]";
      mysql_query ($query) or die (mysql_error());
    }
    if ( mysql_num_rows($final_result) >= 1 ) { //Product In new table
      $new_row = mysql_fetch_assoc($new_result); //Get the data into an array so we can compare the prices
      if ( $row['price'] < $final_row['price'] ) { //New price is lower
        $query = "UPDATE `final_table` SET `dist` = 'A', `price` = '".$row['price']."' [Other Vars that need update] WHERE `sku` LIKE '"$row['sku']"'";
        mysql_query ($query) or die (mysql_error());
      }
    }
  }
}

然后对 B 和 C 表重复此操作,更新表名和放入最终数据库的值。

(我意识到我可能在那个例子中违反了一些约定,但这个概念就在那里。)

这确实假设了一些事情,主要sku是某种唯一索引。

于 2012-05-14T20:32:59.253 回答