MySQL LOAD DATA INFILE 使用详解

5星 · 超过95%的资源 6 下载量 79 浏览量 更新于2024-08-30 收藏 119KB PDF 举报
"MySQL的LOAD DATA INFILE操作" MySQL的`LOAD DATA INFILE`语句用于高效地从外部文本文件中批量导入数据到数据库表中。它比使用一系列的`INSERT`语句更快,尤其适用于大数据量的导入。该语句支持在服务器端或者客户端(通过`LOCAL`关键字)读取文件。 ### 1. `LOCAL` 关键字 如果使用`LOCAL`关键字,文件从客户端机器上传到服务器进行处理。如果不指定`LOCAL`,文件则需要存在于服务器的数据库目录中,并且必须具有可读权限。`LOCAL`选项在MySQL 3.22.6及更高版本中可用。 ### 2. 安全性与权限 为了安全考虑,如果文件位于服务器上,它必须位于数据库目录内,或者对所有用户都是可读的。同时,执行`LOAD DATA INFILE`需要在服务器主机上拥有`FILE`权限。 ### 3. 文件格式与默认设置 `LOAD DATA INFILE`语句允许你自定义字段和行的分隔符。默认情况下,字段由制表符分隔,没有引号包围,而行由换行符终止。这意味着如果文件中的数据格式与这些默认设置不符,导入可能会失败。 ### 4. FIELDS 和 LINES 子句 - **FIELDS TERMINATED BY**: 指定字段间的分隔符,默认是制表符`\t`。 - **FIELDS ENCLOSED BY**: 如果字段值需要用引号包围,可以指定引号类型,默认是没有引号的。 - **FIELDS ESCAPED BY**: 用于转义特殊字符,默认是反斜杠`\`。 - **LINES TERMINATED BY**: 指定行结束符,默认是换行符`\n`。 ### 5. 错误处理与示例 在导入时,如果文件格式与`LOAD DATA INFILE`的默认设置不匹配,将会导致导入失败。例如,如果文件中的数据是逗号分隔且用双引号包围,那么必须相应调整`FIELDS TERMINATED BY`和`FIELDS ENCLOSED BY`的值。 ```sql LOAD DATA INFILE 'file_name.csv' INTO TABLE table_name FIELDS TERMINATED BY ',' ENCLOSED BY '"' LINES TERMINATED BY '\n'; ``` 在上述例子中,`file_name.csv`是包含数据的文件,`table_name`是要导入数据的表名,逗号用于字段分隔,双引号用于包围字段值,每行以换行符结束。 ### 6. PHP 中的使用 在PHP中,可以使用`mysql_query()`函数执行`LOAD DATA INFILE`语句。但是,请注意,`mysql_*`系列函数已废弃,推荐使用`mysqli`或`PDO`扩展进行数据库操作。 ```php $connection = mysqli_connect('host', 'username', 'password', 'database'); $sql = "LOAD DATA INFILE 'file_path' INTO TABLE table_name"; $result = mysqli_query($connection, $sql); if (!$result) { die("Import failed: " . mysqli_error($connection)); } mysqli_close($connection); ``` 在上述代码中,确保`file_path`是服务器上的绝对路径,`table_name`替换为实际的表名,连接参数根据实际情况配置。 `LOAD DATA INFILE`是MySQL中一种高效的数据导入工具,需要根据文件格式正确配置语句,确保导入的成功。同时,安全性和权限问题也不容忽视,尤其是在服务器上处理文件时。