如果不存在,则导入和更新或添加新行CSV MYSQL

时间:2017-02-13 12:33:43

标签: php mysql csv import-csv

我有一个我正在为某人创建的自动库存,我已正确完成更新。值已成功更新。但是,我注意到我使用的mysql没有添加出现在更新中的新行。我试着让它自己工作,但到目前为止我没有运气。有人可以解释为什么这不起作用吗?主表是'product_list'

CREATE TEMPORARY TABLE temp_update_table (SKU VARCHAR(50), PRODUCT_NAME VARCHAR(255), QTY smallint(6), COMMENTS text);

// Create Temporary Table

LOAD DATA LOCAL INFILE '/home/useraccount/products.csv' INTO TABLE temp_update_table FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '\"' LINES TERMINATED BY '\n' (SKU, PRODUCT_NAME, QTY);

// Insert CSV Contents into table

UPDATE product_list INNER JOIN temp_update_table on temp_update_table.SKU = product_list.SKU SET product_list.QTY = temp_update_table.QTY;

// Update Current Quantities to match new ones.

INSERT INTO product_list(SKU, PRODUCT_NAME, QTY) SELECT NEW.SKU, NEW.PRODUCT_NAME, NEW.QTY  FROM temp_update_table as NEW LEFT JOIN product_list as OLD ON OLD.SKU = NEW.SKU WHERE OLD.SKU IS NULL:"

// If there are any new rows, add them (This is the line where the problem lies?)

DROP TEMPORARY TABLE temp_update_table;
// Remove Temp Table

如果有人能说出一些亮点,那就太棒了!没有任何sql错误..所以它我错误地调用了..

1 个答案:

答案 0 :(得分:1)

我在加载临时表后使用重复键来解决我的问题:

insert into product_list(SKU,PRODUCT_NAME,QTY)
select SKU, PRODUCT_NAME, QTY FROM temp_update_table
ON DUPLICATE KEY UPDATE QTY = values(QTY);

抱歉这个愚蠢的问题!