LOAD DATA INFILE REPLACE 似乎不适用于多个字段?

发布于 2024-09-09 01:38:29 字数 500 浏览 5 评论 0原文

我正在使用 php 将文件加载到表中。我创建一个像这样的表:

CREATE TABLE IF NOT EXISTS $table (
`id` INT AUTO_INCREMENT PRIMARY KEY,
`order` INT DEFAULT 0,
`data` VARCHAR(200) UNIQUE,
`cur_timestamp` TIMESTAMP DEFAULT NOW())";

并从这样的文本文件填充它:

LOAD DATA LOCAL 
INFILE '".$file ."' REPLACE 
INTO TABLE $table 
FIELDS TERMINATED BY '^' 
(`order`,`data`)";

即使我使用 REPLACE 并且数据是唯一的,它也会创建重复的记录,除非记录中的顺序和数据都相同。有人可以建议我哪里出错了吗?我只希望它根据数据匹配替换记录。我一遍又一遍地阅读文档,这对我来说看起来很正确。

I'm loading a file into a table with php. I create a table like this:

CREATE TABLE IF NOT EXISTS $table (
`id` INT AUTO_INCREMENT PRIMARY KEY,
`order` INT DEFAULT 0,
`data` VARCHAR(200) UNIQUE,
`cur_timestamp` TIMESTAMP DEFAULT NOW())";

And fill it from a text file like this:

LOAD DATA LOCAL 
INFILE '".$file ."' REPLACE 
INTO TABLE $table 
FIELDS TERMINATED BY '^' 
(`order`,`data`)";

Even though I'm using REPLACE and data is UNIQUE it creates duplicate records unless order and data are both the same in the record. Can someone suggest where I'm going wrong? I only want it to replace records based on matches to data. I've read the documentation over and over, this looks right to me.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

莫多说 2024-09-16 01:38:29

我认为制作数据 KEY 可以做到这一点,但如果顺序不同它仍然会插入

CREATE TABLE IF NOT EXISTS $table (
`id` INT AUTO_INCREMENT KEY,
`order` INT DEFAULT 0,
`data` VARCHAR(200) UNIQUE KEY,
`cur_timestamp` TIMESTAMP DEFAULT NOW())";

I thought making making data KEY would do it, but it still inserts if order is different

CREATE TABLE IF NOT EXISTS $table (
`id` INT AUTO_INCREMENT KEY,
`order` INT DEFAULT 0,
`data` VARCHAR(200) UNIQUE KEY,
`cur_timestamp` TIMESTAMP DEFAULT NOW())";
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文