我正在使用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
)?
答案 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),
...;