【MySQL】将表导出CSV(可以使用excel打开)

1、准备工作

查看数据库:

复制代码
show databases;

切换数据库:

复制代码
use 数据库名;

查看表名字

复制代码
show tables;

2、单个表导出

需要替换导出csv文件目录和表名

sql 复制代码
SELECT *
INTO OUTFILE '目录/文件名.csv'
FIELDS TERMINATED BY ','
ENCLOSED BY '"'
LINES TERMINATED BY '\n'
FROM 表名;

如果表太大,excel无法打开,可以显示导出的行数,例如10000行

sql 复制代码
SELECT *
INTO OUTFILE '目录/文件名.csv'
FIELDS TERMINATED BY ','
ENCLOSED BY '"'
LINES TERMINATED BY '\n'
FROM 表名
LIMIT 10000;

3、导出全部表

当表太多的时候,可以使用下面的方法,一次性导出全部表;

需要替换数据库名。

sql 复制代码
DELIMITER //
 
CREATE PROCEDURE ExportAllTablesToCSV()
BEGIN
    DECLARE done INT DEFAULT FALSE;
    DECLARE tName VARCHAR(255);
    DECLARE tCursor CURSOR FOR SELECT table_name FROM information_schema.tables WHERE table_schema = '数据库名';
    DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
 
    OPEN tCursor;
        read_loop: LOOP
            FETCH tCursor INTO tName;
            IF done THEN
                LEAVE read_loop;
            END IF;
 
            SET @stmt = CONCAT('SELECT * FROM ', tName, ' INTO OUTFILE \'', tName, '.csv\' FIELDS TERMINATED BY \',\' OPTIONALLY ENCLOSED BY \'"\' LINES TERMINATED BY \'\n\'');
            PREPARE s1 FROM @stmt;
            EXECUTE s1;
            DEALLOCATE PREPARE s1;
        END LOOP;
    CLOSE tCursor;
END //
 
DELIMITER ;
 
CALL ExportAllTablesToCSV();

4、修复

如果在导出时,报错:

复制代码
Table '表名' is marked as crashed and should be repaired

检查表:

复制代码
check table 表名;

修复表:

复制代码
repair table 表名;
相关推荐
云和数据.ChenGuang6 小时前
批量给100台服务器装系统,还要完成后续的配置和软件部署
运维·服务器·开发语言·mysql
程序员卷卷狗6 小时前
为什么MySQL默认使用可重复读RR?深入解析binlog与隔离级别的关系
数据库·mysql
SoleMotive.7 小时前
redis和mysql有什么区别,以及redis和mysql都有什么缺点,以及什么地方redis不如mysql?
数据库·redis·mysql
聪明努力的积极向上7 小时前
【MYSQL】IN查询优化
数据库·mysql
梁萌8 小时前
MySQL主从数据同步实战
数据库·mysql
嘻哈baby8 小时前
MySQL主从复制与读写分离实战指南
数据库·mysql·adb
q_19132846958 小时前
基于SpringBoot2+Vue2的装修报价网站
java·vue.js·spring boot·mysql·计算机毕业设计·演示文稿
Neolnfra9 小时前
SMB、FTP、MySQL... 配置不当,即是漏洞
linux·数据库·mysql·安全·网络安全·系统安全·安全架构
风月歌9 小时前
小程序项目之驾校报名小程序源代码(java+vue+小程序+mysql)
java·vue.js·mysql·小程序·毕业设计·源码
dllxhcjla9 小时前
MySQL单表
数据库·mysql