热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

mysql数据库的备份以及表格数据之间的复制

mysql数据库的备份以及表格数据之间的复制
mysql数据库的备份以及表格数据之间的复制_MySQL

#####-------------mysql数据备份以及表间数据的复制-------------------#####
##----------------我的mysql学习(二)--------------------------###
##mysql数据的导入和导出--这里承接上一部分
#导出全部数据库该操作在mysql命令行外进行:
导出数据格式如下:

mysqldump -hlocalhost -uroot -p databasename tablename > filename.sql

#预输入sql命令:

mysqldump -uroot -p --default-character-set=gbk mydb > E:/mydb.sql

#弹出输入密码提示,输入密码即可导出数据库。.sql文件中不包含创建数据库的语句
#有的仅仅是对表的操作。

C:/Users/trsli>mysqldump -uroot -p --default-character-set=gbk mydb > E:/myd
b.sql
Enter password: ****

#导出成功数据库,我们将数据库重新导入MySQL中,实现方法如下所示:
首先需要重新建立一个数据库,或者用已经存在的数据库,这里新建一数据库:

#create database mydb1 default character set gbk;

然后进行如下操作导入数据库:

C:/Users/trsli>mysql -uroot -p mydb1 

或者在mydb1下直接用如下命令:

source E:/mydb.sql

#两种方式效果一样,现在检查mydb1中是否存在该表已经表中是否有数据。

mysql> use mydb1;Database changedmysql> 
show tables;
+-----------------+| Tables_in_mydb1 |+-----------------+| mytable 
|+-----------------+1 row in set (0.00 sec)
mysql> 
select * from mytables;
+----+--------+-------+
| id | name | count |
+----+--------+-------+
| 1 | 张三 | 1000 |
| 2 | 李四 | 500 |
| 3 | 王老虎 | 100 |
| 4 |
 赵大 | 1000 |
 | 5 | 王二小 | 500 |
 | 6 | 三亚子 | 100 |
 +----+--------+-------+

6 rows in set (0.00 sec)
#该数据与数据库mydb数据库中显示一致。
#在数据库众多的表中,如果我们只需要导出某一张表格,那么我们可以进行如下操作:

mysqldump -uroot -p mydb1 mytable > E:/mydb1.sql
C:/Users/trsli>mysqldump -uroot -p mydb1 mytable > E:/mydb1.sqlEnter password: ****

#在导出数据过程中有一些参数如:-d --add-drop-table,这里看一下有什么效果:
#这里只添加-d:

C:/Users/trsli>mysqldump -uroot -p -d mydb1 mytable > E:/mydb2.sql
Enter password: ****

#在导出的文件中会少了插入数据的sql语句,只有创建表的sql语句存在。
################------>.sql文件中德语句

LOCK TABLES `mytable` WRITE;
/*!40000 ALTER TABLE `mytable` DISABLE KEYS */;
INSERT INTO `mytable` VALUES (1,'张三',1000),(2,'李四',500),(3,'王老虎',100)
,(4,'赵大',1000),(5,'王二小',500),(6,'三亚子',100);
/*!40000 ALTER TABLE `mytable` ENABLE KEYS */;
UNLOCK TABLES;
################----->该区域sql语句将不会显示

#下面添加--add-drop -table语句:

C:/Users/trsli>mysqldump -uroot -p --add-drop-table mydb1 mytable > E:/mydb3
.sql
Enter password: ****

#该结果与未添加差不多,也许个人观察不够仔细。
#最后同时添加:-d --add-drop-table查看效果

C:/Users/liyuanjie>mysqldump -uroot -p -d --add-drop-table mydb mytable > E:/myd
b3.sql
Enter password: ****

#该效果与只添加-d一致
####-----------------以上方式可用于数据库备份----------------####

####-----------------以下是批量添加表数据的操作--------------####
#这些在网上都有现成的范例,但是我觉得只有自己亲手做过才能算是真的明白所以有了以下的操作
#这里要做的就是关于表中数据的复制,上面我们介绍过通过.txt文本添加数据,这里介绍表格间复制数据:
#现在创建一个新的表:mytab

mysql> create table mytab(
-> id int primary key auto_increment,
-> name varchar(20) not null,
-> age int not null,
-> salary int not null
-> )type=InnoDB;
Query OK, 0 rows affected, 1 warning (0.07 sec)

#给该表添加4个字段
#这里用前面介绍的文件导入数据方式向空表mytab中添加数据
#load data local infile 'E:/mydb.txt' into table mytab(name,salary,age);

mysql> load data local infile 'E:/mydb.txt' into table mytab(name,salary,age);
Query OK, 3 rows affected (0.06 sec)Records: 3 Deleted: 0 Skipped: 0 Warnings: 0
mysql> select * from mytab;
+----+--------+-----+--------+| id | name | age | salary |+----+--------+-----+--------+| 
1 | ?阿琼 | 23 | 1000 || 2 | 秋水虾 | 24 | 500 || 3 | 害人精 | 22 | 100 |+----+--------+-----+--------+

3 rows in set (0.01 sec)

#如何将mytab中的数据复制到mytable中,就是我们下面需要做的。mytable中数据如最上边所示:

#insert into mytable (name,count) select name,salary from mytab ;
mysql> select * from mytable;
+----+--------+-------+| id | name | count |+----+--------+-------+| 1 | 张三 | 1000 || 2 | 李四 | 500 || 3 | 
王老虎 | 100 || 4 | 赵大 | 1000 || 5 | 王二小 | 500 || 6 | 三亚子 | 100 || 7 | ?阿琼 | 1000 || 8 | 秋水虾 | 500 
|| 9 | 害人精 | 100 |+----+--------+-------+

9 rows in set (0.00 sec)
#可以看到数据以及增加了三行,即将全表导入

#进行不重复插入数据操作:
这里先删除最后一条数据:

#delete from mytable where id=9;
mysql> delete from mytable where id=9;Query OK, 1 row affected (0.10 sec)

#按照预期应该只会插入一条语句,看一下是不是如此呢,下面我们先写一个sql的草稿:
#insert into mytable(name,count) select name,salary from mytab where not exists (select * from mytable where name=mytab.name);
#上面的语句就是将重名的剔除,添加非重名数据

mysql> insert into mytable(name,count) select name,salary from mytab where not e
xists (select * from mytable where name=mytab.name);
Query OK, 1 row affected (0.06 sec) #影响一行数据
Records: 1 Duplicates: 0 Warnings: 0

#小注:在这里我用了较长时间才写好该sql语句,没办法,略显不专业哈。

#####----------------关于向表格中添加数据的操作暂时结束-----####
#以后还会将一些关于mysql配置文件my.conf相关的东西,由于对于数据库整体把我不是太好,切勿见怪。

以上就是mysql数据库的备份以及表格数据之间的复制_MySQL的内容,更多相关内容请关注PHP中文网(www.php1.cn)!

推荐阅读
  • 本文探讨了如何使用Scrapy框架构建高效的数据采集系统,以及如何通过异步处理技术提升数据存储的效率。同时,文章还介绍了针对不同网站采用的不同采集策略。 ... [详细]
  • PHP中Smarty模板引擎自定义函数详解
    本文详细介绍了如何在PHP的Smarty模板引擎中自定义函数,并通过具体示例演示了这些函数的使用方法和应用场景。适合PHP后端开发者学习。 ... [详细]
  • 解决ADODB连接Access时出现80004005错误的方法
    本文详细介绍了如何解决在使用ADODB连接Access数据库时遇到的80004005错误,包括错误原因分析和具体的解决步骤。 ... [详细]
  • 本文详细解析了MySQL中常见的几种错误,并提供了具体的解决方法,帮助开发者快速定位和解决问题。 ... [详细]
  • 本文探讨了如何在PHP与MySQL环境中实现高效的分页查询,包括基本的分页实现、性能优化技巧以及高级的分页策略。 ... [详细]
  • 本文介绍了如何通过安装 sqlacodegen 和 pymysql 来根据现有的 MySQL 数据库自动生成 ORM 的模型文件(model.py)。此方法适用于需要快速搭建项目模型层的情况。 ... [详细]
  • Java连接MySQL数据库的方法及测试示例
    本文详细介绍了如何安装MySQL数据库,并通过Java编程语言实现与MySQL数据库的连接,包括环境搭建、数据库创建以及简单的查询操作。 ... [详细]
  • 本文详细介绍了如何使用SQL*Plus连接Oracle数据库以及使用MySQL客户端连接MySQL数据库的方法,包括基本命令和具体操作步骤。 ... [详细]
  • egg实现登录鉴权(七):权限管理
    权限管理包含三部分:访问页面的权限,操作功能的权限和获取数据权限。页面权限:登录用户所属角色的可访问页面的权限功能权限:登录用户所属角色的可访问页面的操作权限数据权限:登录用户所属 ... [详细]
  • 本文详细介绍了MySQL InnoDB存储引擎中的Redo Log和Undo Log,探讨了它们的工作原理、存储方式及其在事务处理中的关键作用。 ... [详细]
  • 本文探讨了MySQL中的死锁现象及其监控方法,并介绍了如何通过配置和SQL语句调整来优化数据库性能。同时,还讲解了慢查询日志的配置与分析技巧。 ... [详细]
  • C/C++ 应用程序的安装与卸载解决方案
    本文介绍了如何使用Inno Setup来创建C/C++应用程序的安装程序,包括自动检测并安装所需的运行库,确保应用能够顺利安装和卸载。 ... [详细]
  • 本文介绍了如何在 Oracle 数据库中查询重复数据,并提供了多种方法来筛选和删除重复记录,包括基于单个字段和多个字段的重复数据处理。 ... [详细]
  • 最适合初学者的编程语言
    本文探讨了适合编程新手的最佳语言选择,包括Python、JavaScript等易于上手且功能强大的语言,以及如何通过有效的学习方法提高编程技能。 ... [详细]
  • 在Android应用开发过程中,开发者经常遇到诸如CPU使用率过高、内存泄漏等问题。本文将介绍几种常用的命令及其应用场景,帮助开发者有效定位并解决问题。 ... [详细]
author-avatar
寒灵
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有