RHEL 5服务篇—管理以及备份Mysql数据库系统-阿里云开发者社区

开发者社区> 科技小先锋> 正文

RHEL 5服务篇—管理以及备份Mysql数据库系统

简介:
+关注继续查看

    上一遍文章中,我们已经学会了怎么安装Mysql数据了,那么我们怎么样管理以及使用Mysql呢?Mysql是一套数据库管理系统,在每一台Mysql服务器中,支持运行对个库,每个库相当于一个容器,其中存放着许许多多的表,表中的每一行包含一条具体的数据关系信息。

1、查看Mysql数据中的库和表

首先我们需要连接Mysql数据,只有连接了Mysql数据才可以查看里面的内容。

[root@localhost /]#mysql -u root -p

Enter password:

mysql>

show databases语句:用于列出当前Mysql服务器中包含的库,默认有三个库:test,mysql和information_schema(其中mysql库中包含了用户认证相关的表)

073859183.jpg

show tables语句:用于列出当前所在的库中的所有表,在操作之前需要先使用use语句切换到目标库。

074345282.jpg

describe语句:用于显示表的结构,及组成表的各字段的信息。需要指定“库名.表名”,若只需要指定表名,则需要使用use语句切换到指定的库。

075252101.jpg




2、创建及删除数据库和表

create database 语句:用于创建一个新的库,需要指定数据库名称作为参数。

080010913.jpg

Mysql数据库的数据文件默认存放在“/usr/lcoal/mysql/var/”目录下,每个数据库对应一个子目录,用于存储数据表文件。

080326929.jpg

create table语句:用于在当前库中创建新的表,需要指定数据名称作为参数,并指定该表所使用的各字段。

格式如:create    table    表名 (字段1名称 类型,字段2名称 类型,....,primapy(主键名))

列如:创建一个users表,有用户名和密码两列,用户名不能超过16个字符串,密码不能超过48个字符串,将用户名的列设为主键,将密码列默认设为空值。

091809245.jpg

数据表文件存储在对应的数据库目录下,默认在”/usr/lcoal/mysql/var/bbs/”目录下,每个数据表对应为三个文件,后缀分别为“.frm“,”.MYD”,“.MYI“。

094148494.jpg

drop table语句:用于删除库中的表,需要指定“库名.表名“做为参数;若只指定表名,需要先进表所在的数据库。

092817173.jpg

drop database语句:用于删除指定的数据库,需要指定库名作为参数。

093140895.jpg




3、管理表中的数据记录

insert into 语句:用于向表中插入新的数据记录。

列如:向刚才新建表中插入一条新的记录。

095000741.jpg

在插入新的数据记录时,如果这条记录完整包括表中所有字段的值,则插入语句中指定的字段部分可以省略。

095301346.jpg

select 语句:用于从指定的表中查找符合条件的数据记录。

格式:select 字段1,字段2, ... from 表名 where 条件表达式

095741733.jpg

如果要实现多表查询,则这些表之间一定要有关联(两张表中有相同的列),否则不可实现多表查询。

101830614.jpg

update 语句:用于修改,更新表中的数据记录。

在Mysql数据库中,数据用户的信息都保存在Mysql库中的user表中,我们可以通过修改user表中的记录来更改用户的信息。列如:将Mysql的管理员密码改掉。

102643232.jpg

delete 语句:用于删除表中指定的数据记录。

列如:删除bbs数据库中users表中lisi的记录。

103120818.jpg




管理Mysql数据库的用户,以及用户授权

grant 语句:专门用来设置数据库用户的访问权限。当指定的用户名不存在时,grant语句将会创建新的用户,否则grant语句用于修改用户的信息。

格式:grant 权限列表 on 库名.表名 to 用户名@来源地址 [ identified by ‘ 密码’ ]

权限类表:用于列出授权使用的各种数据库操作,以逗号进行分隔,all表示所有权限。

库名.表名:用于指定受权限操作的库和表的名称,可以使用”*“通配符。

用户名@来源地址:用于指定用户名和允许访问的地址,来源地址可以是域名,IP,还可以使用”%“通配符表示某个区域或网段。列如:”%.benet.com“、”192.168.1.%“等

列如:创建一个blog用户对于bbs数据库的所有访问权限。

110157270.jpg

show grants for语句:专门用来查看数据库用户的授权信息,通过for子句可指定查看的用户对象(必须与授权时使用的对象名称一致)。

格式:show grants for 用户名@来源地址

111405240.jpg

revoke 语句:用于撤销指定用户的数据库权限。

格式:revoke 权限列表 on 数据库名.表名 from 用户名@来源地址

112924492.jpg




Mysql数据库的备份与恢复

Mysql数据库的备份可以采用多种方式,列如直接打包数据库文件”/usr/lcoal/mysql/var/“,或者使用专用的导出工具Mysqldump来完成。下面我们就来使用专用的工具mysqldump工具来备份数据库。

备份数据库

通过mysqldump命令可以将指定的库,表或全部的库导出为sql脚本,便于该命令在不同版本的mysql服务器上使用。使用Mysqldump命令导出数据时,默认会在终端显示,若要保存到文件,还需要结合shell的”>“重定向输出操作。

备份表、格式:mysql [选项] 库名 [表名1] [表名2]  ... > /备份路径/备份文件名

备份库、格式:mysql [选项] --databases [表名1] [表名2] ... > /备份路径/备份文件名

备份所有库、格式:mysql [选项] --all-datebases  > /备份路径/备份文件名

常用的选项包括”-u“,”-p“,分别用于指定数据库用户名,密码。

列如:备份bbs数据库中users表

[root@localhost /]#mysqldump -u root -p bbs users > /tmp/users.sql

Enter password:       //输入密码

列如:备份bbs数据库

[root@localhost /]#mysqldump -u root -p --databases bbs > /tmp/bbs.sql

Enter password:       //输入密码

列如:备份整个Mysql中的所有数据库

[root@localhost /]#mysqldump -u root -p --opt --all-databases > /tmp/all-data.sql

Enter password:       //输入密码

若备份整个Mysql数据库时,导出的数据量较大,可以添加”--opt“选项以优化执行速度。


恢复数据库

使用mysqldump命令导出的sql备份脚本,在需要恢复时可以通过mysql命令对其进行导入操作。

格式:mysql [选项] [库名] [表名] < /备份路径/备份文件名

当备份文件中只包含表的备份,而不包含创建库的语句时,则执行导入操作时必须制定库名。

列如:将刚才备份的users表恢复到指定的数据库中。

列如:备份bbs库中users表

[root@localhost /]#mysql -u root -p test < /tmp/users.sql

Enter password:          //输入密码

若备份文件中已经包括完整的库信息,则执行导入操作时无需指定库名。

列如:将刚才备份的bbs数据库还原到数据库中(前提是需要将原有的bbs数据删掉,否则或重名)。

列如:备份bbs库中users表

[root@localhost /]#mysql -u root -p  > /tmp/bbs.sql

Enter password:      //输入密码


掌握上述的各种Mysql管理语句命令,就可以管理基本的数据库工作。如果需要了解更多的Mysql命令,可以参考http://dev.mysql.com/doc/refman/5.1/zh/在线手册。

至此Mysql的基本管理已经讲解完毕了,如果有什么地方写的不是很好,希望大家多多指教,在下感激不尽。



本文转自yun5277 51CTO博客,原文链接:http://blog.51cto.com/dengqi/1215716,如需转载请自行联系原作者


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
PostgreSQL 10.1 手册_部分 III. 服务器管理_第 28 章 监控数据库活动
第 28 章 监控数据库活动 目录 28.1. 标准 Unix 工具 28.2. 统计收集器 28.2.1. 统计收集配置 28.2.2. 查看统计信息 28.2.3. 统计函数 28.3. 查看锁 28.4. 进度报告 28.4.1. VACUUM进度报告 28.5. 动态追踪 28.5.1. 动态追踪的编译 28.5.2. 内建探针 28.5.3. 使用探针 28.5.4. 定义新探针 一个数据库管理员常常会疑惑,“系统现在正在做什么?”这一章会讨论如何搞清楚这个问题。
960 0
PostgreSQL 10.1 手册_部分 III. 服务器管理_第 28 章 监控数据库活动_28.3. 查看锁
28.3. 查看锁 监控数据库活动的另外一个有用的工具是pg_locks系统表。这样就允许数据库管理员查看在锁管理器里面未解决的锁的信息。例如,这个功能可以被用于: 查看当前所有未解决的锁、在一个特定数据库中的关系上所有的锁、在一个特定关系上所有的锁,或者由一个特定PostgreSQL会话持有的所有的锁。
962 0
PostgreSQL 10.1 手册_部分 III. 服务器管理_第 28 章 监控数据库活动_28.1. 标准 Unix 工具
28.1. 标准 Unix 工具 在大部分 Unix 平台上,PostgreSQL会修改由ps报告的命令标题,这样个体服务器进程可以被标识。一个显示样例是 $ ps auxww | grep ^postgres postgres 15551 0.
1142 0
MySql数据库批量备份命令
rd d:\mysql_data-BAK /s /qmd d:\mysql_data-BAKxcopy d:\mysql_data d:\mysql_data-BAK /e
658 0
mysqldump常用于MySQL数据库逻辑备份
mysqldump常用于MySQL数据库逻辑备份。   1、各种用法说明      A. 最简单的用法: mysqldump -uroot -pPassword [database name] > [dump file]      上述命令将指定数据库备份到某dump文件(转储文件)中,比如: mysqldump -uroot -p123 test > test.dump      生成的test.dump文件中包含建表语句(生成数据库结构哦)和插入数据的insert语句。
1014 0
6967
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载