我有一个我正在为某人创建的自动库存,我已正确完成更新。值已成功更新。但是,我注意到我使用的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错误..所以它我错误地调用了..
答案 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);
抱歉这个愚蠢的问题!