
假设如果我们想要上传更改后的值而不是文本文件中写入的值,那么我们需要将用户变量与 SET 命令一起使用。可以通过以下示例来理解 -
示例
假设我们在“A.txt”中有以下数据 -
不少网友非常喜欢三顾购物系统,尤其是喜欢服装版,但是却苦于要收费,而且网上也一直没有免费版。现在将自己修改的版本上传,功能没有任何限制,希望对大家有帮助,为大家创造些价值。 三顾购物系统分为服装版、鲜花版、化妆品版、时尚商务版等多个版本,本系统为服装版,采用三顾购物平台,具备了所有购物网站的功能,应用于服装行业。 三顾购物系统使用说明: 解压后将3gushop文件夹下的所有文件上传到支持AspJp
105,Chum,USA,11000 106,Danny,AUS,12000
但是我们希望在导入时添加 500 后上传薪水值,而不更改文本文件中的薪水值,那么可以通过使用用户变量并借助以下查询来完成使用 SET 选项 -
mysql> LOAD DATA LOCAL INFILE 'd:\A.txt' INTO table employee11_tbl FIELDS TERMINATED BY ',' (id,name,country,@salary) SET salary = @salary + 500; Query OK, 2 rows affected (0.21 sec) Records: 2 Deleted: 0 Skipped: 0 Warnings: 0 mysql> Select * from employee11_tbl; +------+----------------+----------+--------+ | Id | Name | Country | Salary | +------+----------------+----------+--------+ | 105 | Chum | USA | 11500 | | 106 | Danny | AUS | 12500 | +------+----------------+----------+--------+ 2 rows in set (0.00 sec)
从上面的结果集中可以看出,MySQL是在salary的值上加上500之后将数据上传到表中的。









