gpt4 book ai didi

Mysql加载文件

转载 作者:行者123 更新时间:2023-11-29 23:57:16 25 4
gpt4 key购买 nike

我有一个 CSV 文件,其中 Mysql DB 表中的每一行包含一行;每行有 3 个值。前2个直接对应DB表的列,因此可以传递。第三个值包含一个代码,该代码将用作不同数据库表中的“查找”代码,并且该表中的另一列(1:1 关系)将被加载到第一个表中。所以:

  • 表 1:包含 ColA、ColB、ColC
  • 表2:包含LookupCode、LookupValue

CSV 文件包含(每行)ColA、ColB、LookupCode

我想通过 CSV 文件加载到 Table1 中的是:基于 CSV 文件行第 3 列中的 LookupCode FROM Table2 的 ColA、ColB、LookupValue。

我的问题是:我该怎么做?

我尝试了以下形式的 LOAD DATA 语句:

LOAD DATA LOCAL INFILE 'path to CSV file' INTO TABLE Table1
FIELDS TERMINATED BY ','
LINES TERMINATED BY '\n'
(ColA, ColB, @Lookup)
SET ColC = (SELECT LookupValue FROM Table2 WHERE LookupCode = @Lookup LIMIT 1);

但这会导致每个加载行中的 ColC 为 NULL(ColA 和 ColB 没问题)。

如果我使用固定代码而不是@Lookup,例如LookupCode = 'code1' 它将访问 Table2 并填充(相同)相应的列值,即每个加载行的 ColC 中的 value1,因此正在执行 SELECT 语句,但显然不能使用动态值。

作为解决方法,我想我可以向 Table1 添加另一列 ColD 并将 CSV 文件中的 LookupCode 存储在其中,然后运行单独的查询以根据 ColD 的值更新每行 ColC 的值与 SELECT 子句结合使用;但我不想在 Table1 中填写 ColD,而是直接填写 ColC。

最佳答案

我发现为什么我尝试使用的查询不起作用。它与 CSV 文件中的数据有关。第三个字段未正确分隔(不确定确切原因),因此包含不可显示的字符,这些字符影响查询的 SELECT 子句中的比较。当我对 CSV 文件进行全局更新以消除此问题时,LOAD DATA 查询按预期工作。

对于给您带来的任何不便,我们深表歉意。

关于Mysql加载文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25250923/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com