mysqldump
1:option:
mysqldump执行流程:
mysqldump db_name > db_name.sql \\未加任何选项
vim db_name.sql \\可以清楚的看到dump的过程,mysqldump的过程就是将数据和表结构转化为sql语句
- -- MySQL dump 10.10
- --
- -- Host: localhost Database: test
- -- ------------------------------------------------------
- -- Server version 5.0.22-log
- /*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
- /*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
- /*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
- /*!40101 SET NAMES utf8 */;
- /*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
- /*!40103 SET TIME_ZONE='+00:00' */;
- /*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
- /*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
- /*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
- /*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;
- --
- -- Table structure for table `advis_researchuser`
- --
- DROP TABLE IF EXISTS `advis_researchuser`;
- CREATE TABLE `advis_researchuser` (
- `id` int(11) NOT NULL auto_increment,
- `userid` varchar(20) default NULL,
- `pt` varchar(10) default NULL,
- `***` varchar(5) default NULL,
- `age` varchar(10) default NULL,
- `result` varchar(50) default NULL,
- `lastupdate` timestamp NULL default CURRENT_TIMESTAMP,
- `deleted` smallint(1) NOT NULL default '0',
- `phone` varchar(5) default NULL,
- `tv` varchar(5) default NULL,
- PRIMARY KEY (`id`)
- ) ENGINE=MyISAM DEFAULT CHARSET=gbk;
- --
- -- Dumping data for table `advis_researchuser`
- --
- /*!40000 ALTER TABLE `advis_researchuser` DISABLE KEYS */;
- LOCK TABLES `advis_researchuser` WRITE;
- INSERT INTO `articles` VALUES (1,'MySQL Tutorial','DBMS stands for DataBase ...'),(2,'How To Use MySQL Well','After you went through a ...'),(3,'Optimizing MySQL','In this tutorial we will show ...'),(4,'1001 MySQL Tricks','1. Never run mysqld as root. 2. ...'),(5,'MySQL vs. YourSQL','In the following database comparison ...'),(6,'MySQL Security','When configured properly, MySQL ...'),(7,'database','wwww'),(8,'vvvvv','database'),(9,'database','database');
- UNLOCK TABLES;
- /*!40000 ALTER TABLE `advis_researchuser` ENABLE KEYS */;
1:首先创建一个同名表,根据表结构转换成sql语句
DROP TABLE IF EXISTS `advis_researchuser`;
CREATE TABLE `advis_researchuser`
需要注意的是create前首先drop,这就相当于 --add-drop-tables 选项,所以--add-drop-tables默认打开
2:导数据,根据表中数据转化sql语句
-- Dumping data for table `advis_researchuser`
--
/*!40000 ALTER TABLE `advis_researchuser` DISABLE KEYS */;
LOCK TABLES `advis_researchuser` WRITE;
UNLOCK TABLES;
/*!40000 ALTER TABLE `advis_researchuser` ENABLE KEYS */;
过程:在insert是忽略索引,锁表,解锁,统一建索引
说明:1:首先忽略索引的好处:加快insert的速度
2:锁表不是dump执行就全库锁表,锁定当前导出数据表(等同于--lock-table),这个选项只适合myisam引擎,innodb引擎要用--single-transaction,所以--lock-table默认也是打开的
3:数据导出完毕,解锁当前表
4:统一建立表索引
下面开始选项部分(网上很多讲选项的,只是看,不能理解,看过上面的过程就明白啦)以下内容来自网络
--disable-keys
告诉 mysqldump 在 INSERT 语句的开头和结尾增加 ; 和 ; 语句,这能大大提高插入语句的速度,因为它是在插入完所有数据后才重建索引的。该选项只适合 MyISAM 表。
--lock-all-tables, -x
在开始导出之前,提交请求锁定所有数据库中的所有表,以保证数据的一致性。这是一个全局读锁,并且自动关闭 --single-transaction 和 --lock-tables 选项。
--lock-tables
它和 --lock-all-tables 类似,不过是锁定当前导出的数据表,而不是一下子锁定全部库下的表。本选项只适用于 MyISAM 表,如果是 Innodb 表可以用 --single-transaction 选项
--no-create-info, -t
只导出数据,而不添加CREATE TABLE语句。
--no-data, -d
不导出任何数据,只导出数据库表结构。
--opt
这只是一个快捷选项,等同于同时添加 --add-drop-tables --add-locking --create-option --disable-keys --extended-insert --lock-tables --quick --set-charset 选项。本选项能让 mysqldump 很快的导出数据,并且导出的数据能很快导回。该选项默认开启,但可以用 --skip-opt 禁用。注意,如果运行 mysqldump 没有指定 --quick 或 --opt 选项,则会将整个结果集放在内存中。如果导出大数据库的话可能会出现问题。
--quick, -q
该选项在导出大表时很有用,它强制 mysqldump 从服务器查询取得记录直接输出而不是取得所有记录后将它们缓存到内存中。
--routines, -R
导出存储过程以及自定义函数。
--single-transaction
该选项在导出数据之前提交一个 BEGIN SQL语句,BEGIN 不会阻塞任何应用程序且能保证导出时数据库的一致性状态。它只适用于事务表,例如 InnoDB 和 BDB。
本选项和 --lock-tables 选项是互斥的,因为 LOCK TABLES 会使任何挂起的事务隐含提交。
要想导出大表的话,应结合使用 --quick 选项。
--triggers
同时启用触发器,该选项默认启用,用--skip-triggers禁用它。
阅读(2300) | 评论(1) | 转发(0) |