百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

MySQL、PostgreSQL、SQL Server 数据库导入导出实操全解

liuian 2025-04-05 20:09 47 浏览

在数字化时代,数据是关键资产,数据库的导入导出操作则是连接数据与应用场景的桥梁。

以下是常见数据库导入导出的实用方法及代码,包含更多细节和特殊情况处理,助你应对各种实际场景。

一、MySQL数据库

(一)导出操作

1. 导出为SQL文件:

命令:

mysqldump -u用户名 -p密码 数据库名 > 导出文件名.sql

示例:

mysqldump -uroot -p123456 test_db > test_db_backup.sql

说明:

使用 mysqldump 工具, -u 指定用户名, -p 后紧跟密码,可备份整个数据库结构和数据。

若只想备份特定表,可在数据库名后添加表名,如

 mysqldump -uroot -p123456 test_db users > users_table_backup.sql 

若要同时备份多个表,可依次列出表名,如

mysqldump -uroot -p123456 test_db users orders > combined_backup.sql 

另外, --single-transaction 参数可在导出时保持事务一致性,适用于在线数据库导出,命令为 mysqldump -u用户名 -p密码 --single-transaction 数据库名 > 导出文件名.sql 。

2. 导出为CSV文件:

命令:

SELECT *
FROM 表名
INTO OUTFILE '/导出路径/文件名.csv'
FIELDS TERMINATED BY ','
ENCLOSED BY '"'
LINES TERMINATED BY '\n';

示例:

SELECT *
FROM users
INTO OUTFILE '/var/lib/mysql - files/users.csv'
FIELDS TERMINATED BY ','
ENCLOSED BY '"'
LINES TERMINATED BY '\n';

说明:此方法导出表数据为CSV格式。

若要导出特定字段,可将 SELECT * 改为 SELECT 字段1, 字段2 ;

若带条件导出,如 SELECT * FROM users WHERE age > 18 INTO OUTFILE... 。

注意MySQL对导出路径权限有要求,需确保可写。

如果字段中可能包含特殊字符导致导出混乱,可使用 ESCAPED BY '\\' 来指定转义字符,命令变为 SELECT * FROM 表名 INTO OUTFILE '/导出路径/文件名.csv' FIELDS TERMINATED BY ',' ENCLOSED BY '"' ESCAPED BY '\\' LINES TERMINATED BY '\n'; 。

(二)导入操作

1. 从SQL文件导入

命令:

mysql -u用户名 -p密码 数据库名 < 导入文件名.sql

示例:

mysql -uroot -p123456 test_db < test_db_backup.sql

说明:使用 mysql 客户端,将备份的SQL文件内容执行到指定数据库中。若数据库不存在,需先创建数据库,如 CREATE DATABASE test_db; 。

在导入前,可以先使用 SET FOREIGN_KEY_CHECKS = 0; 来禁用外键检查,加快导入速度,导入完成后再使用 SET FOREIGN_KEY_CHECKS = 1; 恢复外键检查,完整命令流程为:

SET FOREIGN_KEY_CHECKS = 0;

mysql -u用户名 -p密码 数据库名 < 导入文件名.sql

SET FOREIGN_KEY_CHECKS = 1;

2. 从CSV文件导入:

命令:

LOAD DATA INFILE '/导入路径/文件名.csv'
INTO TABLE 表名
FIELDS TERMINATED BY ','
ENCLOSED BY '"'
LINES TERMINATED BY '\n';

示例:

LOAD DATA INFILE '/var/lib/mysql - files/users.csv'
INTO TABLE users
FIELDS TERMINATED BY ','
ENCLOSED BY '"'
LINES TERMINATED BY '\n';

说明:

导入CSV文件数据到表中。

若CSV文件字段顺序与表不一致,可指定字段对应关系,如 LOAD DATA INFILE... INTO TABLE users (字段1, 字段2) ;

若CSV有表头,可添加 IGNORE 1 LINES 忽略首行。

如果CSV文件较大,可以使用 LOCAL 关键字在本地加载文件,提高导入速度,命令变为 LOAD DATA LOCAL INFILE '/导入路径/文件名.csv' INTO TABLE 表名... 。

二、PostgreSQL数据库

(一)导出操作

1. 导出为SQL文件

命令:

pg_dump -U用户名 数据库名 > 导出文件名.sql

示例:

pg_dump -Upostgres demo_db > demo_db_backup.sql

说明: pg_dump 是PostgreSQL备份工具, -U 指定用户名。

可通过添加参数实现不同备份需求,如 -f 指定输出文件路径, -t 指定特定表备份,如

pg_dump -Upostgres -t users demo_db > users_table_backup.sql 

若要进行压缩备份,可以使用 -Z 参数指定压缩级别,例如

 pg_dump -Upostgres -Z 9 demo_db > demo_db_backup.sql.gz ( 9 为最高压缩级别)

2. 导出为CSV文件:

命令:

COPY (SELECT * FROM 表名) TO '/导出路径/文件名.csv' WITH CSV HEADER;

示例:

COPY (SELECT * FROM products) TO '/tmp/products.csv' WITH CSV HEADER;

说明:

COPY 语句导出数据为CSV。若要导出特定条件数据,如

COPY (SELECT * FROM products WHERE price > 100) TO... 

导出部分字段,如

 COPY (SELECT product_id, product_name FROM products) TO... 

如果要导出的数据量较大,可以使用

 COPY (SELECT * FROM 表名) TO STDOUT WITH CSV HEADER;

将数据输出到标准输出,然后通过管道符 > 重定向到文件,例如

COPY (SELECT * FROM products) TO STDOUT WITH CSV HEADER; > large_products.csv 

(二)导入操作

1. 从SQL文件导入

命令:

psql -U用户名 -d数据库名 -f导入文件名.sql

示例:

psql -Upostgres -d demo_db -f demo_db_backup.sql

说明: psql 客户端执行SQL文件导入。确保数据库存在,若不存在需先创建,如

CREATE DATABASE demo_db; 

在导入SQL文件时,可以使用 --echo-all 参数让 psql 在执行每条SQL语句时打印出来,便于调试,命令为 psql -U用户名 -d数据库名 -f导入文件名.sql --echo-all 。

2. 从CSV文件导入:

命令:

COPY 表名 FROM '/导入路径/文件名.csv' WITH CSV HEADER;

示例:

COPY products FROM '/tmp/products.csv' WITH CSV HEADER;

说明:从CSV文件导入数据到表。

若需数据类型转换,如

COPY products (price::numeric) FROM... ;

处理空值,如

COPY products FROM... WITH CSV HEADER NULL AS '' 

如果CSV文件包含特殊字符或编码问题,可以指定编码格式,如

COPY 表名 FROM '/导入路径/文件名.csv' WITH CSV HEADER ENCODING 'UTF8'; 

三、SQL Server数据库

(一)导出操作

1. 导出为.bak文件(完整备份):在SQL Server Management Studio中,依次点击“对象资源管理器” - 右键点击要备份的数据库 - “任务” - “备份”,选“完整”,指定路径和名称,点击“确定”。

说明:完整备份会备份数据库所有数据和日志文件,可用于数据库还原。也可以通过T-SQL语句进行备份,命令为 BACKUP DATABASE 数据库名 TO DISK = '备份文件路径.bak' ,例如 BACKUP DATABASE Northwind TO DISK = 'C:\Backup\Northwind.bak' 。

2. 导出为CSV文件:

命令:

bcp 数据库名.dbo.表名 out /导出路径/文件名.csv -T -c -t,

示例:

bcp Northwind.dbo.Customers out C:\Backup\Customers.csv -T -c -t,

说明:

bcp 工具用于批量数据传输, -T 使用信任连接, -c 用字符数据格式, -t 指定字段分隔符。导出特定行,如

 bcp "SELECT * FROM Northwind.dbo.Customers WHERE City = 'London'" queryout... ;

导出指定字段,如

bcp "SELECT CustomerID, CompanyName FROM Northwind.dbo.Customers" queryout... 

如果要在导出时指定文件的字符编码,可以使用 -C 参数,例如

bcp Northwind.dbo.Customers out C:\Backup\Customers.csv -T -c -t, -C UTF-8

(二)导入操作

1. 从.bak文件还原

在SQL Server Management Studio中,依次点击“对象资源管理器” - 右键点击“数据库” - “还原数据库”,选“源设备”,选.bak文件,选目标数据库和恢复选项,点击“确定”。

说明:还原操作需谨慎,确保备份文件与目标数据库兼容。也可以使用T-SQL语句进行还原,例如完整还原的命令为 RESTORE DATABASE 目标数据库名 FROM DISK = '备份文件路径.bak' WITH RECOVERY ,若要进行差异还原等其他还原方式,需根据具体情况调整参数。

2. 从CSV文件导入

命令:

bcp 数据库名.dbo.表名 in /导入路径/文件名.csv -T -c -t,

示例:

bcp Northwind.dbo.Customers in C:\Backup\Customers.csv -T -c -t,

说明:

使用 bcp 从CSV导入数据。确保表结构与CSV数据匹配,否则可能导入失败。如果CSV文件中的数据需要进行数据转换,可以使用格式文件(.fmt)来指定转换规则,命令中添加 -f 格式文件路径.fmt ,例如

bcp Northwind.dbo.Customers in C:\Backup\Customers.csv -T -c -t, -f C:\Backup\customers.fmt 

数据库的导入导出是数据管理的关键操作,熟练掌握这些方法和代码,可助力数据的高效迁移、备份和分析,满足不同场景需求。

在操作时,务必注意数据安全和文件权限等问题。

相关推荐

教你把多个视频合并成一个视频的方法

一.情况介绍当你有一个m3u8文件和一个目录,目录中有连续的视频片段,这些片段可以连成一段完整的视频。m3u8文件打开后像这样:m3u8文件,可以理解为播放列表,里面是播放视频片段的顺序。视频片段像这...

零代码编程:用kimichat合并一个文件夹下的多个文件

一个文件夹里面有很多个srt字幕文件,如何借助kimichat来自动批量合并呢?在kimichat对话框中输入提示词:你是一个Python编程专家,完成如下的编程任务:这个文件夹:D:\downloa...

Java APT_java APT 生成代码

JavaAPT(AnnotationProcessingTool)是一种在Java编译阶段处理注解的工具。APT会在编译阶段扫描源代码中的注解,并根据这些注解生成代码、资源文件或其他输出,...

Unit Runtime:一键运行 AI 生成的代码,或许将成为你的复制 + 粘贴神器

在我们构建了UnitMesh架构之后,以及对应的demo之后,便着手于实现UnitMesh架构。于是,我们就继续开始UnitRuntime,以用于直接运行AI生成的代码。PS:...

挣脱臃肿的枷锁:为什么说Vert.x是Java开发者手中的一柄利剑?

如果你是一名Java开发者,那么你的职业生涯几乎无法避开Spring。它如同一位德高望重的老国王,统治着企业级应用开发的大片疆土。SpringBoot的约定大于配置、SpringCloud的微服务...

五年后,谷歌还在全力以赴发展 Kotlin

作者|FredericLardinois译者|Sambodhi策划|Tina自2017年谷歌I/O全球开发者大会上,谷歌首次宣布将Kotlin(JetBrains开发的Ja...

kotlin和java开发哪个好,优缺点对比

Kotlin和Java都是常见的编程语言,它们有各自的优缺点。Kotlin的优点:简洁:Kotlin程序相对于Java程序更简洁,可以减少代码量。安全:Kotlin在类型系统和空值安全...

移动端架构模式全景解析:从MVC到MVVM,如何选择最佳设计方案?

掌握不同架构模式的精髓,是构建可维护、可测试且高效移动应用的关键。在移动应用开发中,选择合适的软件架构模式对项目的可维护性、可测试性和团队协作效率至关重要。随着应用复杂度的增加,一个良好的架构能够帮助...

颜值非常高的XShell替代工具Termora,不一样的使用体验!

Termora是一款面向开发者和运维人员的跨平台SSH终端与文件管理工具,支持Windows、macOS及Linux系统,通过一体化界面简化远程服务器管理流程。其核心定位是解决多平台环境下远程连接、文...

预处理的底层原理和预处理编译运行异常的解决方案

若文章对您有帮助,欢迎关注程序员小迷。助您在编程路上越走越好![Mac-10.7.1LionIntel-based]Q:预处理到底干了什么事情?A:预处理,顾名思义,预先做的处理。源代码中...

为“架构”再建个模:如何用代码描述软件架构?

在架构治理平台ArchGuard中,为了实现对架构的治理,我们需要代码+模型描述所要处理的内容和数据。所以,在ArchGuard中,我们有了代码的模型、依赖的模型、变更的模型等,剩下的两个...

深度解析:Google Gemma 3n —— 移动优先的轻量多模态大模型

2025年6月,Google正式发布了Gemma3n,这是一款能够在2GB内存环境下运行的轻量级多模态大模型。它延续了Gemma家族的开源基因,同时在架构设计上大幅优化,目标是让...

比分网开发技术栈与功能详解_比分网有哪些

一、核心功能模块一个基本的比分网通常包含以下模块:首页/总览实时比分看板:滚动展示所有正在进行的比赛,包含比分、比赛时间、红黄牌等关键信息。热门赛事/焦点战:突出显示重要的、关注度高的比赛。赛事导航...

设计模式之-生成器_一键生成设计

一、【概念定义】——“分步构建复杂对象,隐藏创建细节”生成器模式(BuilderPattern):一种“分步构建型”创建型设计模式,它将一个复杂对象的构建与其表示分离,使得同样的构建过程可以创建...

构建第一个 Kotlin Android 应用_kotlin简介

第一步:安装AndroidStudio(推荐IDE)AndroidStudio是官方推荐的Android开发集成开发环境(IDE),内置对Kotlin的完整支持。1.下载And...