LOAD DATA INFILE REPLACE 似乎不适用于多个字段?
我正在使用 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 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
我认为制作数据 KEY 可以做到这一点,但如果顺序不同它仍然会插入
I thought making making data KEY would do it, but it still inserts if order is different