Mysql - 删除空列以仅更新设置值

时间:2013-06-07 09:21:24

标签: php mysql

我正在使用mysql + php。 php提供了将XLSX商品表导入Mysql表的界面。我正在使用一个用CREATE TABLE LIKE创建的临时表,即在与实时表合并之前进行用户评估的空表克隆

我正在使用INSERT INTO finalTable SELECT * FROM importTable ON DUPLICATE KEY UPDATE ....来避免每条记录INSERT。要在重复键上更新的字段由php使用SHOW COLUMNS确定,即临时表中的所有列。

我的问题是XLSX不一定包含所有字段(名称,价格,类别),即它可能只是现有记录的更新。当前方法将更新所有字段,无论它们是否在导入期间设置,即如果XLSX仅包含价格更新,则其余字段为空并且将覆盖当前值。

我试图通过删除所有行为空的列(而不是行!)来更改临时表。这样SHOW COLUMNS只返回可更新列。如果需要将字段归零,则可以很容易地设置特殊值,例如“!X!”并使用单UPDATE句来做。

有没有这方法,或者你有更好的建议(我也愿意放弃ON DUPLICATE KEY)?

1 个答案:

答案 0 :(得分:3)

我对你的问题感到有点困惑。

  

我正在使用INSERT ... ON DUPLICATE KEY UPDATE以避免对每条记录进行INSERT。

就像它说的,它插入或更新,你不会避免任何事情。如果要避免插入,请使用INSERT IGNORE

如果我是你,我会分两步合并这些表格。

第一步,插入(只是必要的插入):

INSERT INTO finalTable (col1, col2, ...)
SELECT i.col1, i.col2
FROM importTable i 
LEFT JOIN finalTable f  ON i.ID = f.ID
WHERE f.ID IS NULL;

第二步,更新:

我不明白,为什么要删除列。不必要的步骤可能需要一段时间,而且最重要的是,如果您的导入表中的一列中只有几行NULL,则使用NULL进行更新的问题仍然存在。所以,这是解决方案。

UPDATE finalTable f
INNER JOIN importTable i ON f.ID = i.ID
SET f.col1 = COALESCE(i.col1, f.col1),
f.col2 = COALESCE(i.col2, f.col2),
...;

第二步的技巧是使用COALESCE()。此函数返回其第一个非null的参数。因此,如果导入表中的列为null,则最终表中的值保持不变。

更新:

如果你坚持只发表一个声明,你当然可以

INSERT INTO final f
SELECT * FROM import i
ON DUPLICATE KEY UPDATE
SET f.col1 = COALESCE(i.col1, f.col1),
f.col2 = COALESCE(i.col2, f.col2),
...;