默认情况下,mysqldump对整个数据库进行备份。我需要在MySQL中备份一个表。这可能吗?我怎么恢复它?


当前回答

你可以使用下面的代码:

对于单表结构单独备份

-

mysqldump -d <database name> <tablename> > <filename.sql>

对于单表结构的数据

-

mysqldump <database name> <tablename> > <filename.sql>

希望能有所帮助。

其他回答

我们可以在任何给定条件下对任何特定的表进行mysql转储,如下所示

mysqldump -uusername -p -hhost databasename tablename --skip-lock-tables

如果我们想在表上添加一个特定的where条件,那么我们可以使用下面的命令

mysqldump -uusername -p -hhost databasename tablename --where="date=20140501" --skip-lock-tables

Mysqldump可以接受一个tbl_name参数,这样它只备份给定的表。

mysqldump -u -p yourdb yourtable > c:\backups\backup.sql

你可以使用下面的代码:

本例对sugarcrm数据库进行备份,并将输出转储到sugarcrm.sql

# mysqldump -u root -ptmppassword sugarcrm > sugarcrm.sql

# mysqldump -u root -p[root_password] [database_name] > dumpfilename.sql

sugarcrm。对于sugarcrm数据库中的所有表,SQL将包含删除表、创建表和插入命令。以下是sugarcrm的部分输出。Sql,显示accounts_contacts表的转储信息:

--

——accounts_contacts表的表结构

DROP TABLE IF EXISTS `accounts_contacts`;
SET @saved_cs_client = @@character_set_client;
SET character_set_client = utf8;
CREATE TABLE `accounts_contacts` (
`id` varchar(36) NOT NULL,
`contact_id` varchar(36) default NULL,
`account_id` varchar(36) default NULL,
`date_modified` datetime default NULL,
`deleted` tinyint(1) NOT NULL default '0',
PRIMARY KEY (`id`),
KEY `idx_account_contact` (`account_id`,`contact_id`),
KEY `idx_contid_del_accid` (`contact_id`,`deleted`,`account_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
SET character_set_client = @saved_cs_client;

--

从.sql中转储和恢复单个表

Dump

mysqldump db_name table_name > table_name.sql

从远程数据库转储

mysqldump -u <db_username> -h <db_host> -p db_name table_name > table_name.sql

如需进一步参考:

http://www.abbeyworkshop.com/howto/lamp/MySQL_Export_Backup/index.html

恢复

mysql -u <user_name> -p db_name
mysql> source <full_path>/table_name.sql

或者在一行里

Mysql -u username -p db_name < /path/to/table_name.sql . Mysql


从压缩(.sql.gz)格式转储和恢复单个表

资料来源:John McGrath

Dump

mysqldump db_name table_name | gzip > table_name.sql.gz

恢复

gunzip < table_name.sql.gz | mysql -u username -p db_name

你可以使用下面的代码:

对于单表结构单独备份

-

mysqldump -d <database name> <tablename> > <filename.sql>

对于单表结构的数据

-

mysqldump <database name> <tablename> > <filename.sql>

希望能有所帮助。