MySQL转CSV文件

MySQL转CSV文件

 
#! /usr/bin/php
 
<?php
$filename = "outdata.csv";
$db = mysql_connect(DBHOST, DBUSER, DBPASS);
mysql_select_db(DBNAME);
 
//$sql = "set names utf8";
//$query = mysql_query($sql, $db);
 
$sql = "select * from t_table";
$query = mysql_query($sql, $db);
 
if (false === $query) {
    echo "Can't query";
    exit(1);
}
 
$fp = fopen($filename, 'a');
if (false === $fp) {
    echo "Can't open./n";
    exit(1);
}
 
while ($entry = mysql_fetch_array($query, MYSQL_NUM)) {
    array_walk($entry, 'userData');
    if (false === fwrite($fp, join(",", $entry)."/n")) {
        echo "Can't write./n";
        exit(1);
    }
}
 
if (fclose($fp)) {
    echo "Complete!/n";
}
 
// -------------------------------------------------------- function -------------------------------------------------------- //
 
function userData(&$value) {
    $value = preg_replace("//"/", '""', $value);
    if (strpos($value, "/"") || strpos($value, ",")) {
        $value = "/"".$value."/"";
    }
}
?>
### 如何在 MySQL 中导入、导出或存储 CSV 文件MySQL 中,CSV 文件的导入、导出和存储是一个常见的需求。以下是详细的说明: #### 1. 导出 MySQL 表为 CSV 文件 可以使用 `SELECT ... INTO OUTFILE` 语句将 MySQL 表中的数据导出为 CSV 文件。此方法允许用户指定文件路径、字段分隔符、行结束符等。 示例代码如下: ```sql SELECT first_name, last_name, email FROM account INTO OUTFILE '/path/to/output.csv' FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' LINES TERMINATED BY '\n'; ``` 上述代码将表 `account` 的数据导出到 `/path/to/output.csv` 文件中[^3]。需要注意的是,路径必须是服务器上的可写路径,并且可能需要管理员权限。 #### 2. 导入 CSV 文件MySQL 表 可以通过 `LOAD DATA INFILE` 或 `LOAD DATA LOCAL INFILE` 将 CSV 文件中的数据导入到 MySQL 表中。以下是一个典型的导入命令: ```sql LOAD DATA LOCAL INFILE 'F:\\document\\37\\TYCD.csv' INTO TABLE cd_id CHARACTER SET gb2312 FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' ESCAPED BY '"'; ``` 上述代码将本地路径 `F:\\document\\37\\TYCD.csv` 的 CSV 文件导入到表 `cd_id` 中,并指定了字符集为 `gb2312`,以避免中文乱码问题[^4]。 #### 3. 存储 CSV 文件作为 MySQL 数据 如果需要直接将 CSV 文件的内容存储到 MySQL 数据库中而不进行换,可以创建一个与 CSV 文件结构匹配的表,然后通过 `LOAD DATA INFILE` 命令将其导入。例如: ```sql CREATE TABLE csv_data ( column1 VARCHAR(255), column2 INT, column3 DATE ); LOAD DATA LOCAL INFILE '/path/to/input.csv' INTO TABLE csv_data FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n'; ``` #### 4. 解决常见问题 - 如果运行 `SELECT ... INTO OUTFILE` 或 `LOAD DATA INFILE` 报错 `#1290 – The MySQL server is running with the –secure-file-priv option`,则需要检查 MySQL 配置文件中的 `secure_file_priv` 参数。该参数限制了文件操作的路径[^5]。 - 确保 MySQL 用户有足够的权限访问目标路径或源路径。 - 在导入或导出时,需注意字符编码问题,尤其是在处理包含中文或其他非 ASCII 字符的数据时。 #### 5. 使用 GUI 工具(如 Navicat) 除了命令行操作外,还可以使用图形化工具(如 Navicat)来简化导入和导出操作。例如,在 Navicat 中选择要导出的表,按下快捷键 `Ctrl+Q` 打开查询窗口,输入相应的 SQL 语句即可完成操作[^2]。 ```python # 示例:Python 脚本读取 CSV 并插入 MySQL import csv import mysql.connector conn = mysql.connector.connect( host="localhost", user="root", password="password", database="test" ) cursor = conn.cursor() with open('data.csv', 'r') as file: reader = csv.reader(file) for row in reader: cursor.execute("INSERT INTO table_name (col1, col2, col3) VALUES (%s, %s, %s)", row) conn.commit() cursor.close() conn.close() ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值