只涉及到 mysqldump
工具的使用,没有 binlog
日志的恢复
备份 1. 导出所有数据 1 mysqldump -uroot -proot --all-database > all.sql
2. 备份指定数据库 1 2 3 mysqldump -uroot -proot db1 --add-drop-database > db1.sql mysqldump -uroot -proot --databases db1 db2 --add-drop-database > db1_and_db2.sql
3. 备份指定表 1 2 3 mysqldump -uroot -proot --databases db1 -single-transaction --tables t1 t2 > t1_t2.sql
4. 根据条件导出 1 mysqldump -uroot -proot --databases db1 --tables t1 --where ='id=1' > t1.sql
5. 只导出表结构 1 mysqldump -uroot -proot --no-data --databases db1 > db1.sql
6. 只导出表数据 1 mysqldump -uroot -proot --no-data --databases db1 --tables t1 --no-create-db --no-create-info --skip-add-drop-table > t1.sql
7. 数据不落地导出导入 1 2 3 mysqldump --host=h1 -uroot -proot --databases db1 |mysql --host=h2 -uroot -proot db2 mysqldump --host=h1 -uroot -proot -C --databases test |mysql --host=h2 -uroot -proot test
8. 导出数据为CSV 1 mysqldump -uroot -proot --no-data --databases db1 --tables t1 --fields-terminated-by ',' > t1.sql
9. 使用sql语句备份指定查询的数据 1 select * from tablename into outfile 'target_file' [option];
option 参数
1 2 3 4 5 6 7 fields terminated by 'string' // 字段分隔符,默认为制表符'\t' fields [optionally] enclosed by 'char' // 字段引用符,如果加 optionally 选项则只用在 char、varchar 和 text 等字符型字段上,默认不使用引用符 fields escaped by 'char' // 转移字符、默认为 '\' lines starting by 'string' // 每行前都加此字符串,默认'' lines terminated by 'string' // 行结束符,默认为'\n' # char 表示此符号只能是单个字符,string表示可以是字符串。
导出csv文件
1 select * from user into outfile 'user.csv' fields terminated by "," optionally enclosed by '"';
恢复 1. 使用sql语句导入数据 1 2 source table.sql mysqldump
2. 导入指定格式的文件 1 load data [local]infile 'filename' into table tablename [option]
option 选项
1 2 3 4 5 6 7 8 fields terminated by 'string' (字段分割符,默认为制表符't') fields [optionally] enclosed by 'char' (字段引用符,如果加 optionally 选项则只用在 char varchar text 等字符型字段上。默认不使用引用符) fields escaped by 'char' (转义字符,默认为'') lines starting by 'string' (每行前都加此字符串,默认为'') lines terminated by 'string' (行结束符,默认为'n') ignore number lines (忽略输入文件中的前几行数据) (col_name_or_user_var,...) (按照列出的字段顺序和字段数量加载数据) set col_name = expr,...将列做一定的数值转换后再加载。
导入csv文件
1 load data infile 'user.csv' into table user fields terminated by ',' enclosed by '"';
mysqldump 参数 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 导出全部数据库。 mysqldump - uroot - p 导出全部表空间。 mysqldump - uroot - p 不导出任何表空间信息。 mysqldump - uroot - p 每个数据库创建之前添加drop 数据库语句。 mysqldump - uroot - p 每个数据表创建之前添加drop 数据表语句。(默认为打开状态,使用 mysqldump - uroot - p mysqldump - uroot - p 在每个表导出之前增加LOCK TABLES并且之后UNLOCK TABLE 。(默认为打开状态,使用 mysqldump - uroot - p mysqldump - uroot - p 允许创建是关键词的列名字。这由表名前缀于每个列名做到。 mysqldump - uroot - p 在'CHANGE MASTER' 前添加'STOP SLAVE' ,并且在导出的最后添加'START SLAVE' 。 mysqldump - uroot - p 字符集文件的目录 mysqldump - uroot - p 附加注释信息。默认为打开,可以用 mysqldump - uroot - p mysqldump - uroot - p 导出的数据将和其它数据库或旧版本的MySQL 相兼容。值可以为ansi、mysql323、mysql40、postgresql、oracle、mssql、db2、maxdb、no_key_options、no_tables_options、no_field_options等, 要使用几个值,用逗号将它们隔开。它并不保证能完全兼容,而是尽量兼容。 mysqldump - uroot - p 导出更少的输出信息(用于调试)。去掉注释和头尾等结构。可以使用选项: mysqldump - uroot - p 使用完整的insert 语句(包含列名称)。这么做能提高插入效率,但是可能会受到max_allowed_packet参数的影响而导致插入失败。 mysqldump - uroot - p 在客户端和服务器之间启用压缩传递所有信息 mysqldump - uroot - p 在CREATE TABLE 语句中包括所有MySQL特性选项。(默认为打开状态) mysqldump - uroot - p 导出几个数据库。参数后面所有名字参量都被看作数据库名。 mysqldump - uroot - p 输出debug信息,用于调试。默认值为:d:t,/ tmp/ mysqldump.trace mysqldump - uroot - p mysqldump - uroot - p 检查内存和打开文件使用说明并退出。 mysqldump - uroot - p 输出调试信息并退出 mysqldump - uroot - p 设置默认字符集,默认值为utf8 mysqldump - uroot - p 采用延时插入方式(INSERT DELAYED)导出数据 mysqldump - uroot - p master备份后删除日志. 这个参数将自动激活 mysqldump - uroot - p 对于每个表,用;和;语句引用INSERT 语句。这样可以更快地导入dump出来的文件,因为它是在插入所有行后创建索引的。该选项只适合MyISAM表,默认为打开状态。 mysqldump - uroot - p 该选项将主的binlog位置和文件名追加到导出数据的文件中(show slave status)。设置为1 时,将会以CHANGE MASTER命令输出到数据文件;设置为2 时,会在change前加上注释。该选项将会打开 mysqldump - uroot - p mysqldump - uroot - p 该选项将当前服务器的binlog的位置和文件名追加到输出文件中(show master status)。如果为1 ,将会输出CHANGE MASTER 命令;如果为2 ,输出的CHANGE MASTER命令前添加注释信息。该选项将打开 - single- transaction也被指定(在这种情况下,全局读锁在开始导出时获得很短的时间;其他内容参考下面的mysqldump - uroot - p mysqldump - uroot - p 导出事件。 mysqldump - uroot - p 使用具有多个VALUES 列的INSERT 语法。这样使导出文件更小,并加速导入时的速度。默认为打开状态,使用 mysqldump - uroot - p mysqldump - uroot - p 导出文件中忽略给定字段。与 mysqldump - uroot - p test test 输出文件中的各个字段用给定字符包裹。与 mysqldump - uroot - p test test 输出文件中的各个字段用给定字符选择性包裹。与 mysqldump - uroot - p test test 输出文件中的各个字段忽略给定字符。与 mysqldump - uroot - p mysql user 开始导出之前刷新日志。 请注意:假如一次导出多个数据库(使用选项 mysqldump - uroot - p 在导出mysql数据库之后,发出一条FLUSH PRIVILEGES 语句。为了正确恢复,该选项应该用于导出mysql数据库和依赖mysql数据库数据的任何时候。 mysqldump - uroot - p 在导出过程中忽略出现的SQL 错误。 mysqldump - uroot - p 显示帮助信息并退出。 mysqldump 使用十六进制格式导出二进制字符串字段。如果有二进制数据就必须使用该选项。影响到的字段类型有BINARY 、VARBINARY 、BLOB 。 mysqldump - uroot - p 需要导出的主机信息 mysqldump - uroot - p 不导出指定表。指定忽略多个表时,需要重复多次,每次一个表。每个表必须同时指定数据库和表名。例如: mysqldump - uroot - p 在 mysqldump - uroot - p 在插入行时使用INSERT IGNORE语句. mysqldump - uroot - p 输出文件的每行用给定字符串划分。与 mysqldump - uroot - p 提交请求锁定所有数据库中的所有表,以保证数据的一致性。这是一个全局读锁,并且自动关闭 mysqldump - uroot - p 开始导出前,锁定所有表。用READ LOCAL 锁定表以允许MyISAM表并行插入。对于支持事务的表例如InnoDB和BDB, 请注意当导出多个数据库时, mysqldump - uroot - p 附加警告和错误信息到给定文件 mysqldump - uroot - p 服务器发送和接受的最大包长度。 mysqldump - uroot - p TCP/ IP和socket连接的缓存大小。 mysqldump - uroot - p 使用autocommit/ commit 语句包裹表。 mysqldump - uroot - p 只导出数据,而不添加CREATE DATABASE 语句。 mysqldump - uroot - p 只导出数据,而不添加CREATE TABLE 语句。 mysqldump - uroot - p 不导出任何数据,只导出数据库表结构。 mysqldump - uroot - p 等同于 mysqldump - uroot - p 等同于 mysqldump - uroot - p 如果存在主键,或者第一个唯一键,对每个表的记录进行排序。在导出MyISAM表到InnoDB表时有效,但会使得导出工作花费很长时间。 mysqldump - uroot - p 连接数据库密码 使用命名管道连接mysql mysqldump - uroot - p 连接数据库端口号 使用的连接协议,包括:tcp, socket, pipe, memory. mysqldump - uroot - p 不缓冲查询,直接导出到标准输出。默认为打开状态,使用 mysqldump - uroot - p mysqldump - uroot - p 使用(`)引起表和列名。默认为打开状态,使用 mysqldump - uroot - p mysqldump - uroot - p 使用REPLACE INTO 取代INSERT INTO . mysqldump - uroot - p 直接输出到指定文件中。该选项应该用在使用回车换行对(\\r\\n)换行的系统上(例如:DOS,Windows)。该选项确保只有一行被使用。 mysqldump - uroot - p 导出存储过程以及自定义函数。 mysqldump - uroot - p 添加'SET NAMES default_character_set' 到输出文件。默认为打开状态,使用 mysqldump - uroot - p mysqldump - uroot - p 该选项在导出数据之前提交一个BEGIN SQL 语句,BEGIN 不会阻塞任何应用程序且能保证导出时数据库的一致性状态。它只适用于多版本存储引擎,仅InnoDB。本选项和 mysqldump - uroot - p 将导出时间添加到输出文件中。默认为打开状态,使用 mysqldump - uroot - p mysqldump - uroot - p 禁用–opt选项. mysqldump - uroot - p 指定连接mysql的socket文件位置,默认路径/ tmp/ mysql.sock mysqldump - uroot - p 为每个表在给定路径创建tab分割的文本文件。注意:仅仅用于mysqldump和mysqld服务器运行在相同机器上。 mysqldump - uroot - p 覆盖 mysqldump - uroot - p 导出触发器。该选项默认启用,用 mysqldump - uroot - p 在导出顶部设置时区TIME_ZONE= '+00:00' ,以保证在不同时区导出的TIMESTAMP 数据或者数据被移动其他时区时的正确性。 mysqldump - uroot - p 指定连接的用户名。 输出多种平台信息。 输出mysqldump版本信息并退出 只转储给定的WHERE 条件选择的记录。请注意如果条件包含命令解释符专用空格或字符,一定要将条件引用起来。 mysqldump - uroot - p 导出XML格式. mysqldump - uroot - p 客户端插件的目录,用于兼容不同的插件版本。 mysqldump - uroot - p 客户端插件默认使用权限。 mysqldump - uroot - p