每天晚上 00:00 执行 mysql 数据备份,请写出 crontab 配置项
答案: 0 0 * * * mysqldump -uroot -p123456 --flush-logs 数据库名 > 备份文件名
每天凌晨 1 点在 /data 目录新建当天日期文件夹?
答案: 0 1 * * * mkdir /data/$(date "+%Y%m%d")
46,MySQL 如何给 testuser 用户对 testdb 数据库所有表授权访问,密码为 testpwd,请写出命令?
答案: grant all on testdb.* to testuser@"localhost" identified by "testpwd"
47、设置数据库管理员从本机登录的密码为 999
答案:mysqladmin -hlocalhost -uroot -p password "999"
48、授权管理员用户可以在网络中的所有主机登录,对所有库 、表有完全权限且有授权的权限、 登陆密码
tarena
答案:
mysql -hlocalhost -uroot -p999
grant all on *.* to root@"%" identified by "tarena" with grant option;
49、查看当前登陆数据库服务器的用户是谁?
答案: select user();
50、查看当前登陆数据库服务器用户的权限?
答案: show grants;
51、查看当前数据库服务器有哪些授权用户。
答案: select user,host from mysql.user;
52、不允许数据库管理员在数据库服务器本机登录。 答案:
delete from mysql.user where host in ("127.0.0.1","::1","localhost","svr5.tarena.com"); flush privileges;
授权 userweb 用户可以从网络中的任意主机访问数据库服务器,对 studb 库下的 tuser 表有查看、更新username 字段和 age 字段的权限 登录密码 userweb888。
答案:
grant select,update(username,age) on studb.tuser to userweb@"%" identified by "userweb888"; mysql -h192.168.4.5 -uuserweb -puserweb888
授权用户 userweb 重置自己的登陆密码为 123456,并验证能否使用新密码登陆
答案: set password=password(“123456”);
数据库管理员修改授权用户 userweb 的登录密码为 654321,让授权用户 userweb 使用新密码登陆数据库服务器。
答案:
mysql -h192.168.4.5 -uroot -ptarena
set password for userweb@"%"=password("654321"); mysql -h192.168.4.5 -uuserweb -p654321
撤销授权用户 userweb 的所有授权并 使其不再能使用此用户连接数据库服务器。答案:
mysql -h192.168.4.5 -uroot -ptarena
revoke all on studb.tuser from userweb@"%";
delete from mysql.user where user="userweb" and host="%"; flush privileges;
授权 webadmin 用户可以从网络中的所有主机登录,对 bbsdb 库拥有完全权限,且有授权权限,登录密码为webadmin
答案:
grant all on bbsdb.* to webadmin@"%" identified by "webadmin" with grant
option;
grant insert on mysql.* to webadmin@"%" ;
在客户端使用授权用户 webadmin 登录,把自己的权限授权给 userone 用户 登录密码是 userone。答案:
mysql -h192.168.4.5 -uwebadmin -pwebadmin
grant all on bbsdb.* to userone@"%" identified by "userone";
撤销 webadmin 用户的授权权限。答案:
mysql -h192.168.4.5 -uroot -ptarena
revoke grant option on bbsdb.* to webadmin@"%" ;
让所有授权用户连接数据库服务器后,对 test 库无任何权限答案:
delete from mysql.db where user=""; flush privileges;
只允许数据库管理员从数据库服务器本机登录且有授权的权限 , 登录的密码 123plj456。答案:
mysql -h192.168.4.5 -uroot -ptarena
grant all on *.* to root@"localhost" identified by "123plj456" with grant option; quit
mysql -hlocalhost -uroot -p123plj456
delete from mysql.user where host!="localhost"; flush privileges;
1、什么是关系型数据库?
关系型数据库,是指采用了关系模型来组织数据的数据库,其以行和列的形式存储数据,以便于用户理解,关系型数据库这一系列的行和列被称为表,一组表组成了数据库。用户通过查询来检索数据库中的数据,而查询是一个用于限定数据库中某些区域的执行代码。
简单来说,关系模式就是二维表格模型。
2、关系型数据库有什么优势?
关系型数据库的优势:
- 易于理解
关系型二维表的结构非常贴近现实世界,二维表格,容易理解。
- 支持复杂查询 可以用 SQL 语句方便的在一个表以及多个表之间做非常复杂的数据查询。
- 支持事务 可靠的处理事务并且保持事务的完整性,使得对于安全性能很高的数据访问要求得以实现。
3、什么是SQL
结构化查询语言 (Structured Query Language) 简称SQL,是一种特殊目的的编程语言,是一种数据库查询和程序设计语言程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统。
4、什么是MySQL?
MySQL 是一个关系型数据库管理系统,MySQL 是最流行的关系型数据库管理系统之一,常见的关系型数据库还有 Oracle 、SQL Server、Access 等等。
MySQL在过去由于性能高、成本低、可靠性好,已经成为最流行的开源数据库,广泛地应用在 Internet 上的中小型网站中。
5、MySQL 和 MariaDB 傻傻分不清楚?
MySQL 最初由瑞典 MySQL AB 公司开发,MySQL 的创始人是乌尔夫·米卡埃尔·维德纽斯,常用昵称蒙提(Monty)。
在被甲骨文公司收购后,现在属于甲骨文公司(Oracle) 旗下产品。Oracle 大幅调涨MySQL商业版的售价,因此导致自由软件社区们对于Oracle是否还会持续支持MySQL社区版有所隐忧。
MySQL 的创始人就是之前那个叫 Monty 的大佬以 MySQL为基础成立分支计划 MariaDB。
MariaDB打算保持与MySQL的高度兼容性,确保具有库二进制奇偶校验的直接替换功能,以及与MySQL API 应用程序接口)和命令的精确匹配。而原先一些使用 MySQL 的开源软件逐渐转向 MariaDB 或其它的数据库。
所以如果看到你公司用的是 MariaDB 不用怀疑,其实它骨子里还是 MySQL,学会了MySQL 也就会了 MariaDB。
6、如何查看MySQL当前版本号?
在系统命令行下:mysql -V
连接上MySQL命令行输入:
status;
Server: MySQL
Server version: 5.5.45
Protocol version: 10
或 select version();
+------------------------+
| version() |
+------------------------+
| 5.5.45-xxxxx |
+------------------------+
7、MySQL 有哪些数据类型?
MySQL 数据类型非常丰富,常用类型简单介绍如下:
整数类型:BIT、BOOL、TINY INT、SMALL INT、MEDIUM INT、 INT、 BIG INT
浮点数类型:FLOAT、DOUBLE、DECIMAL
字符串类型:CHAR、VARCHAR、TINY TEXT、TEXT、MEDIUM TEXT、LONGTEXT、TINY BLOB、BLOB、MEDIUM BLOB、LONG BLOB
日期类型:Date、DateTime、TimeStamp、Time、Year
其他数据类型:BINARY、VARBINARY、ENUM、SET…
8、CHAR 和 VARCHAR的区别?
CHAR 是固定长度的字符类型,VARCHAR 则是可变长度的字符类型,下面讨论基于在 MySQL5.0 以上版本中。
共同点
CHAR(M) 和 VARCHAR(M) 都表示该列能存储 M 个字符,注意不是字节!!
CHAR类型特点
- CHAR 最多可以存储 255 个字符 (注意不是字节),字符有不同的编码集,比如 UTF8 编码 (3字节)、GBK 编码 (2字节)
等。 - 对于 CHAR(M) 如果实际存储的数据长度小于M,则 MySQL
会自动会在它的右边用空格字符补足,但是在检索操作中那些填补出来的空格字符会被去掉。
VARCHAR类型特点
- VARCHAR 的最大长度为 65535 个字节。
- VARCHAR
存储的是实际的字符串加1或2个字节用来记录字符串实际长度,字符串长度小于255字节用1字节记录,超过255就需要2字节记录。[^12 ]
9、VARCHAR(50) 能存放几个 UTF8 编码的汉字?
存放的汉字个数与版本相关。
mysql 4.0以下版本,varchar(50) 指的是 50 字节,如果存放 UTF8 格式编码的汉字时(每个汉字3字节),只能存放16 个。
mysql 5.0以上版本,varchar(50) 指的是 50 字符,无论存放的是数字、字母还是 UTF8 编码的汉字,都可以存放 50 个。
10、int(10) 和 bigint(10)能存储的数据大小一样吗?
不一样,具体原因如下:
- int 能存储四字节有符号整数。
- bigint 能存储八字节有符号整数。
所以能存储的数据大小不一样,其中的数字 10 代表的只是数据的显示宽度。[^13]
- 显示宽度指明Mysql最大可能显示的数字个数,数值的位数小于指定的宽度时数字左边会用空格填充,空格不容易看出。
- 如果插入了大于显示宽度的值,只要该值不超过该类型的取值范围,数值依然可以插入且能够显示出来。
- 建表的时候指定 zerofill 选项,则不足显示宽度的部分用 0 填充,如果是 1 会显示成 0000000001。
- 如果没指定显示宽度, bigint 默认宽度是 20 ,int默认宽度 11。
11、MySQL存储引擎类型有哪些?
常用的存储引擎有 InnoDB 存储引擎和 MyISAM 存储引擎,InnoDB 是 MySQL 的默认事务引擎。
查看数据库表当前支持的引擎,可以用下面查询语句查看 :
# 查询结果表中的 Engine 字段指示存储引擎类型。
show table status from 'your_db_name' where name='your_table_name';
12、InnoDB存储引擎应用场景是什么?
InnoDB 是 MySQL的默认「事务引擎」,被设置用来处理大量短期(short-lived)事务,短期事务大部分情况是正常提交的,很少会回滚。
InnoDB存储引擎特性有哪些?
采用多版本并发控制(MVCC,MultiVersion Concurrency Control)来支持高并发。并且实现了四个标准的隔离级别,通过间隙锁next-key locking策略防止幻读的出现。
引擎的表基于聚簇索引建立,聚簇索引对主键查询有很高的性能。不过它的二级索引secondary index非主键索引中必须包含主键列,所以如果主键列很大的话,其他的所有索引都会很大。因此,若表上的索引较多的话,主键应当尽可能的小。另外InnoDB的存储格式是平台独立。
InnoDB做了很多优化,比如:磁盘读取数据方式采用的可预测性预读、自动在内存中创建hash索引以加速读操作的自适应哈希索引(adaptive hash index),以及能够加速插入操作的插入缓冲区(insert buffer)等。
InnoDB通过一些机制和工具支持真正的热备份,MySQL 的其他存储引擎不支持热备份,要获取一致性视图需要停止对所有表的写入,而在读写混合场景中,停止写入可能也意味着停止读取。
13、InnoDB 引擎的四大特性是什么?
插入缓冲(Insert buffer)
Insert Buffer 用于非聚集索引的插入和更新操作。先判断插入的非聚集索引是否在缓存池中,如果在则直接插入,否则插入到 Insert Buffer 对象里。再以一定的频率进行 Insert Buffer 和辅助索引叶子节点的 merge 操作,将多次插入合并到一个操作中,提高对非聚集索引的插入性能。
二次写 (Double write)
Double Write由两部分组成,一部分是内存中的double write buffer,大小为2MB,另一部分是物理磁盘上共享表空间连续的128个页,大小也为 2MB。在对缓冲池的脏页进行刷新时,并不直接写磁盘,而是通过 memcpy 函数将脏页先复制到内存中的该区域,之后通过doublewrite buffer再分两次,每次1MB顺序地写入共享表空间的物理磁盘上,然后马上调用fsync函数,同步磁盘,避免操作系统缓冲写带来的问题。
自适应哈希索引 (Adaptive Hash Index)
InnoDB会根据访问的频率和模式,为热点页建立哈希索引,来提高查询效率。索引通过缓存池的 B+ 树页构造而来,因此建立速度很快,InnoDB存储引擎会监控对表上各个索引页的查询,如果观察到建立哈希索引可以带来速度上的提升,则建立哈希索引,所以叫做自适应哈希索引。
缓存池
为了提高数据库的性能,引入缓存池的概念,通过参数 innodb_buffer_pool_size 可以设置缓存池的大小,参数 innodb_buffer_pool_instances 可以设置缓存池的实例个数。缓存池主要用于存储以下内容:
缓冲池中缓存的数据页类型有:索引页、数据页、undo页、插入缓冲 (insert buffer)、自适应哈希索引(adaptive hash index)、InnoDB存储的锁信息 (lock info)和数据字典信息 (data dictionary)。
14、MyISAM存储引擎应用场景有哪些?
MyISAM 是 MySQL 5.1 及之前的版本的默认的存储引擎。MyISAM 提供了大量的特性,包括全文索引、压缩、空间函数(GIS)等,但MyISAM 不「支持事务和行级锁」,对于只读数据,或者表比较小、可以容忍修复操作,依然可以使用它。
15、MyISAM存储引擎特性有哪些?
MyISAM「不支持行级锁而是对整张表加锁」。读取时会对需要读到的所有表加共享锁,写入时则对表加排它锁。但在表有读取操作的同时,也可以往表中插入新的记录,这被称为并发插入。
MyISAM 表可以手工或者自动执行检查和修复操作。但是和事务恢复以及崩溃恢复不同,可能导致一些「数据丢失」,而且修复操作是非常慢的。
对于 MyISAM 表,即使是BLOB和TEXT等长字段,也可以基于其前 500 个字符创建索引,MyISAM 也支持「全文索引」,这是一种基于分词创建的索引,可以支持复杂的查询。
如果指定了DELAY_KEY_WRITE选项,在每次修改执行完成时,不会立即将修改的索引数据写入磁盘,而是会写到内存中的键缓冲区,只有在清理键缓冲区或者关闭表的时候才会将对应的索引块写入磁盘。这种方式可以极大的提升写入性能,但是在数据库或者主机崩溃时会造成「索引损坏」,需要执行修复操作。
16、MyISAM 与 InnoDB 存储引擎 5 大区别
- InnoDB支持事物,而MyISAM不支持事物
- InnoDB支持行级锁,而MyISAM支持表级锁
- InnoDB支持MVCC, 而MyISAM不支持
- InnoDB支持外键,而MyISAM不支持
- InnoDB不支持全文索引,而MyISAM支持
一张表简单罗列两种引擎的主要区别,如下图:
mysql引擎对比
17、SELECT COUNT(*) 在哪个引擎执行更快?
SELECT COUNT(*) 常用于统计表的总行数,在 MyISAM 存储引擎中执行更快,前提是不能加有任何WHERE条件。
这是因为 MyISAM 对于表的行数做了优化,内部用一个变量存储了表的行数,如果查询条件没有 WHERE 条件则是查询表中一共有多少条数据,MyISAM 可以迅速返回结果,如果加 WHERE 条件就不行。
InnoDB 的表也有一个存储了表行数的变量,但这个值是一个估计值,所以并没有太大实际意义。
1范式:1NF是对属性的原子性约束,要求属性具有原子性,不可再分解;(只要是关系型数据库都满足1NF)
2范式:2NF是对记录的惟一性约束,要求记录有惟一标识,即实体的惟一性;
3范式:3NF是对字段冗余性的约束,即任何字段不能由其他字段派生出来,它要求字段没有冗余。没有冗余的数据库设计可以做到
但是,没有冗余的数据库未必是最好的数据库,有时为了提高运行效率,就必须降低范式标准,适当保留冗余数据,具体做法是:在概念数据模型设计时遵守第三范式,降低范式标准的工作放到物理数据模型设计时考虑,降低范式就是增加字段,允许冗余。
- DDL:数据定义语言(create alter drop)
- DML:数据操作语句(insert update delete)
- DTL:数据事务语句(commit collback savapoint)
- DCL:数据控制语句(grant revoke)
- 当不再需要该表时可以用 drop 来删除表;
- 当仍要保留该表,但要删除所有记录时, 用 truncate来删除表中记录。
- 当要删除部分记录时(一般来说有 WHERE 子句约束) 用 delete来删除表中部分记录。
视图是虚拟表,并不储存数据,只包含定义时的语句的动态数据。
创建视图语法:
CREATE
[OR REPLACE]
[ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]
[DEFINER = user]
[SQL SECURITY { DEFINER | INVOKER }]
VIEW view_name [(column_list)]
AS select_statement
[WITH [CASCADED | LOCAL] CHECK OPTION]
参数说明:
- OR REPLACE:如果视图存在,则替换已有视图。
- ALGORITHM:视图选择算法,默认算法是 UNDEFINED(未定义的)由 MySQL自动选择要使用的算法。
- DEFINER:指定视图创建者或定义者,如果不指定该选项,则创建视图的用户就是定义者。
- SQL SECURITY:SQL安全性,默认为DEFINER。
- select_statement:创建视图的 SELECT语句,可以从基表或其他视图中选择数据。
- WITH CHECK OPTION:表示视图在更新时保证约束,默认是 CASCADED。
- 操作简单方便。视图用户完全不需要关心视图对应的表的结构、关联条件和筛选条件,对用户来说已经是过滤好的复合条件的结果集。
- 数据更加安全。视图用户只能访问视图中的结果集,通过视图可以把对表的访问权限限制在某些行和列上面。
- 数据隔离。屏蔽了源表结构变化对用户带来的影响,源表结构变化视图结构不变。^1
默认端口是 3306
查看端口命令:> show variables like ‘port’
DISTINCT 用于对选择的数据去重,单列用法容易理解。比如有如下数据表 tamb:
name number
Tencent 1
Alibaba 2
Bytedance 3
Meituan 3
查询语句:SELECT DISTINCT name FROM table tamb 结果如下:
name
Tencent
Alibaba
Bytedance
Meituan
如果要求按 number 列去重同时显示 name ,你可能会写出查询语句:
SELECT DISTINCT number, name FROM table tamb
多参数 DISTINCT 去重规则是:把 DISTINCT 之后的所有参数当做一个过滤条件,也就是说会对 (number, name)整体去重处理,只有当这个组合不同才会去重,结果如下:
number name
1 Tencent
2 Alibaba
3 Bytedance
3 Meituan
从结果来看好像并没有达到我们想要的去重的效果,那要怎么实现「按 number 列去重同时显示 name」呢?可以用 Group By 语句:
SELECT number, name FROM table tamb GROUP BY number 输出如下,正是我们想要的效果:
number name
1 Tencent
2 Alibaba
3 Bytedance
一条或多条sql语句集合,有以下一些特点:
- 存储过程能实现较快的执行速度。
- 存储过程可以用流程控制语句编写,有很强的灵活性,可以完成复杂的判断和较复杂的运算。
- 存储过程可被作为一种安全机制来充分利用。
- 存储过程能够减少网络流量
delimiter 分隔符
create procedure|proc proc_name()
begin
sql语句
end 分隔符
delimiter ; --还原分隔符,为了不影响后面的语句的使用
--默认的分隔符是;但是为了能在整个存储过程中重用,因此一般需要自定义分隔符(除\外)
show procedure status like ""; --查询存储过程,可以不适用like进行过滤
drop procedure if exists;--删除存储过程
存储过程和函数是事先经过编译并存储在数据库中的一段 SQL 语句的集合,调用存储过程和函数可以简化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于提高数据处理的效率是有好处的。
相同点- 存储过程和函数都是为了可重复的执行操作数据库的 SQL 语句的集合。
- 存储过程和函数都是一次编译后缓存起来,下次使用就直接命中已经编译好的 sql 语句,减少网络交互提高了效率。
- 标识符不同,函数的标识符是 function,存储过程是 procedure。
- 函数返回单个值或者表对象,而存储过程没有返回值,但是可以通过OUT参数返回多个值。
- 函数限制比较多,比如不能用临时表,只能用表变量,一些函数都不可用等,而存储过程的限制相对就比较少。
- 一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强
- 函数的参数只能是 IN 类型,存储过程的参数可以是IN OUT INOUT三种类型。
- 存储函数使用 select 调用,存储过程需要使用 call 调用。
索引是一种数据结构,可以帮助我们快速的进行数据的查找.
27、索引是个什么样的数据结构呢?索引的数据结构和具体存储引擎的实现有关, 在MySQL中使用较多的索引有Hash索引,B+树索引等,而我们经常使用的InnoDB存储引擎的默认索引实现为:B+树索引.
28、从innodb的索引结构分析,为什么索引的key长度不能太长key太长会导致一个页当中能够存放的key的数目变少,间接导致索引树的页数变多,索引层次增加,从而影响整体查询变更的效率。
29、MySQL的数据如何恢复到任意时间恢复到任意时间点以定时的做全量备份,以及备份增量的Binlog日志为前提。恢复到任意时间点首先将全量备份恢复之后,再此基础上回放增加的binlog直至指定的时间点
30、在 MySQL-MMM 集群中有几种角色,各自的功能是什么?参考答案
共 3 种角色:客户端、monitor 节点(管理节点)、agent 节点(数据库节点) 客户端:访问集群
管理节点:负责所有的监控工作的监控守护进程,决定故障节点的移除或恢复
数据库节点:运行在 MySQL 服务器上的代理守护进程,提供简单远程服务集、提供给监控节点(可用来更改只读模式、复制的主服务器等)
参考答案
在 MySQL-MMM 环境中主数据库有且只能有 2 台,从数据库理论上可以任意多台。
参考答案
均衡模式一般用于从数据库,可实现多个虚拟 IP 地址。排他模式一般用于主数据库,只可设置一个虚拟 IP 地址。
MySQL 集群有一些创建高可用性系统的专用功能,主要包括?
答案:节点回复、日志、检查点、系统恢复、热备份恢复、无单点故障、故障转移、分区、联机操作
什么是读写分离?
MySQL Proxy 最强大的一项功能是实现“读写分离(Read/Write Splitting)”。基本的原理是让主数据库处理事务性查询,而从数据库处理 SELECT 查询。数据库复制被用来把事务性查询导致的变更同步到集群中的从数据库。当然,主服务器也可以提供查询服务。使用读写分离最大的作用无非是环境服务器压力。
读写分离的好处
1.增加冗余
2.增加了机器的处理能力
3.对于读操作为主的应用,使用读写分离是最好的场景,因为可以确保写的服务器压力更小,而读又可以接受点时间上的延迟。
mysqldump 是采用 sql 级别的备份机制,将数据表导成 sql 脚本文件,在不用的 mysql 版本之间升级时相对比较合适。
xtranbackup 是 innodb 的 hotbackup 工具,xtrbackup 在启动的时候会复制所有的数据文件,同时会启动一个后台进程,用于监视事务日志,并且从事务日志复制最新的修改。所以 xtrbackup 在启动的开始,就不懂的将事务日志的每个数据文件的修改都记录下来。
mysqldump 的备份和恢复时间都很慢,任何数据的更新和变化都会被挂起。xtrabackup 的恢复时间比 mysqldump 快一点,但是会锁表。
备份恢复失败的话,其实原因很多,主要可能就是参数设置的不对,检查一下参数。
【评析】使用 mysqldump 备份数据表的命令,在 shell 下执行:
mysqldump -u 用户名 -p 密码(可以直接-p) -h 主机名 --databases 数据库名 > 要备份的文件路径mysqldump -u 用户名 -p 密码 -h 主机名 --all-databases >要备份的文件路径
mysqldump -u 用户名 -p 密码 -h 主机名 --no-data 数据库名 >要备份的文件路径
增量备份、差异备份、完整备份