【发布时间】:2014-10-15 23:22:37
【问题描述】:
我下载了一个包含双周数据的文件。由于没有程序包含处理这种格式的选项,我已经调整了我自己的函数来加载这种格式。代码如下所示:
LOAD DATA LOCAL
INFILE '/my_folder/servicios.csv'
INTO TABLE SERVICIOS
FIELDS TERMINATED BY ','
OPTIONALLY ENCLOSED BY '"'
LINES TERMINATED BY '\n'
IGNORE 2 LINES
(@periodo, MERCANCIAS, SERVICIOS, INPC, ENERGETICOS)
SET PERIODO = (SELECT IF(DAY(ld.prd) = 2, ADDDATE(ld.prd,14), ld.prd)
FROM (SELECT DATE(@periodo) AS prd) ld);
SET 语句的作用是将第一周的“2014/10/01”保持原样,但将第二周的“2014/10/02”改为“2014/10/16”。
我知道我可以在 LOAD DATA 语句的 SET 部分中包含子查询。但是,我得到的只是 NULL 值。如果我在外面进行查询,我会得到正确的结果。谁能指出我失败的地方?
最好的问候,
【问题讨论】:
标签: mysql load subquery datatables