Oldguo-MySQL-十万个为什么?(未完待续...)

如果您对数据库感兴趣,可以添加 DBA解决方案QQ群:895979329

1. 业务是什么?

产品的功能
用户的行为(热功能,热数据)

2.你们公司用什么版本数据库?

5.6.38 
5.7.20 

3. 你们公司怎么还在用这么低的版本?

我们这个业务已经运行了4年了,一直用的5.6版本,非常稳定,所以说暂时没有打算升级。

4. GA时间问题漏洞怎么说?

答:刚去上家公司不到两年,交接的时候已经运行了2年多了,我接手的时候版本已经是5.6.38 ,应当是做过小版本的升级。

5. 我们现在公司用的是5.7,你能胜任吗?

能。虽然我们生产中一直使用的5.6,但是我对5.7,8.0的新特性已经足够了解了。所以我完全能够胜任股公司的工作

6. 报错?

[root@db01 bin]# /data/mysql/bin/mysqld --initialize-insecure --user=mysql --basedir=/data/mysql --datadir=/data/mysql/data
/data/mysql/bin/mysqld: error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory
[root@db01 bin]#
[root@db01 ~]# yum install -y libaio-devel

7.关于初始化的新特性(5.6 和 5.7 )

5.6 版本的初始化程序:
/data/mysql/scripts/mysql_install_db --user=mysql --basedir=/data/mysql --datadir=/data/mysql/data
初始化完成后:无密码和无安全策略的

5.7 版本的初始化程序:
(1)
/data/mysql/bin/mysqld --initialize --user=mysql --basedir=/data/mysql --datadir=/data/mysql/data
(2)
/data/mysql/bin/mysqld --initialize-insecure  --user=mysql --basedir=/data/mysql --datadir=/data/mysql/data

提示:5.7以后初始化命令变为bin/mysqld命令,提供了两种初始化方式
第一种初始化方式:开启临时密码和安全策略
第二种初始化方式和之前版本一样,是无密码无安全策略。
演示:

2019-04-03T03:40:15.595883Z 1 [Note] A temporary password is generated for root@localhost: **MWht)!4%sa,3**
安全策略?
密码的复杂度进行了要求,对于密码的过期时间设置了限制

8. 启动报错

image
思路是看日志,日志行中[ERROR]的

9.报错

image
以上问题是:已经启动了,在此启动会说文件占用

10.为什么数据库连接不上?

没启动,账号密码错误,IP 、port 、 socket,分配不了连接线程

11.报错

image

12. SQL92是什么?

关系型数据库中(MySQL,Oracle,MSSQL,DB2,PG):SQL语句的标准

13. 问题

[root@db01 ~]# mysql -uroot -p -S /tmp/mysql.sock -h 10.0.0.51 -P3306
Enter password:
mysql> show processlist;
+----+------+------------+------+---------+------+----------+------------------+
| Id | User | Host      | db  | Command | Time | State    | Info            |
+----+------+------------+------+---------+------+----------+------------------+
| 15 | root | localhost  | NULL | Sleep  |  25 |          | NULL            |
| 16 | root | db01:39646 | NULL | Query  |    0 | starting | show processlist |
+----+------+------------+------+---------+------+----------+------------------+
2 rows in set (0.00 sec)

14. mysql root密码忘记了?

1. 挂维护页
2. 关数据库
[root@db01 ~]# systemctl stop mysqld
3. 跳过授权启动
[root@db01 ~]# mysqld_safe --skip-grant-tables --skip-networking &
--skip-grant-tables : 连接层关闭验证模块,所有验证表不加载。
--skip-networking :连接层关闭TCP/IP协议,禁止远程访问。
4. 改密码
mysql> alter user root@'localhost' identified by '456';
ERROR 1290 (HY000): The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement
mysql>
mysql>
mysql>
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
mysql> alter user root@'localhost' identified by '456';
Query OK, 0 rows affected (0.00 sec)
mysql>
[root@db01 ~]# pkill mysqld
[root@db01 ~]# systemctl start mysqld
5.正常开启业务

15. 初始化配置优先级

命令行>配置文件>预编译

16. mysql命令行显示定义

prompt=Master [\\d]>

17.报错

image

18.数据库启动不了

1.先看日志
2. 配置文件
3. 数据
4. 终极大招 mysqld  --defaults-file=xxxx --user=mysql &

19. char和varchar的优缺点,生产如何选择?

char(11) :***定长***的字符串类型,在存储字符串时,最大字符长度11个,立即分配11个字符长度的存储空间,如果存不满,***空格***填充。
varchar(11):***变******长***的字符串类型看,最大字符长度11个。在存储字符串时,自动判断字符长度,***按需***分配存储空间。
优缺点:
1. char类型存储时,相比varchar类型存储效率更高,不需要判断字符长度,直接分配磁盘空间
2.varchar类型,相比char类型,按需分配空间。
选择?
1. 从原则上来讲,将来字符串长度不固定的话,选择varchar类型,字符串长度固定不变则选择char类型
2. 实际上我们生产中在考虑性能问题的方面,需要有大量插入(insert)操作的应用中,我们可以考虑使用char去代替varchar。
3. 如果我们业务中,大量是查询类操作的应用中,数据量级又比较大情况下,变长长度数据类型,可以考虑采用varchar,一方面节省空间,可以有效的减少***索引树***的高度,从而提高索引的优化查询的效果。

20. 为什么数据库名,不能有大写字母。

开发环境通常是windows的,不区分大小写,线上环境通常是Linux,区分大小写的。

21 . 领导让你熟悉数据库业务

1. 和开发混到好,直接找他要ER图
2. 谁也不认识:
use xuexiao 
show tables;
desc xuesheng;
show create table xuesheng;
select  *  from xuesheng  where  id <5
create table ceshi like xuesheng; (复制结构一样的空表)
  1. union 和 union all区别
union 对结果集进行去重复,union all 不去重复
  1. 在5.7 中,sql_mode使用的是严格模式
sql_mode=only_full_group_by
参数的意思是:
在select 后的查询列,必须是在group by出现过的列,或者使用函数括起来的。
否则group by语句会报错
image

24. b-tree与b+tree的区别?

叶子节点中,会存储相邻叶子结点的指针,可以很大程度优化范围查询(> < >= <=)

25. 为什么char和varchar会对索引高度产生影响?

变长长度字符串,使用char类型,在数据量级很大的时候,使用此列建索引高度变高
 为什么表设计时设置为非空?
针对辅助索引,如果出现大量空值,会导致索引失效

26. 联合索引使用原则:

1. 如果是where条件后有多列等值查询,那么只需要将这多列进行联合索引即可(= and or  in)
但是,我们建索引是尽量将唯一值多的列放在前面,尽量满足优化器的算法规则
2.如果是 where A   group by B  order by C,必须按照语句的执行顺序建立联合索引

27. SQL面试题

image

image
select e.emp_id,e.emp_name,count(c.course_id) from e
join c 
on e.emp_id=c.emp_id
where e.dept_name='技术部';
image
select e.dept,t.course,count(emp_id)
from e 
join c
on e.emp_id=c.emp_id
join t
on c.course_id=t.course_id
where c.score>=60
image
select e.emp_id,e.emp_name ,
case c.score
when c.score< 60
then '不及格'
when c.score >=60 and c.scoe <70
then '及格'
when score >=70 and c.scoe <85
then '良好'
when score >=85 
then '优秀'
END as '评级'
from e
join c
on e.emp_id=c.emp_id
join t
on c.course_id=t.corse_id
where t.tea_name='张三'
image
select e.detp_name ,e.emp_name,t.course_name,count(c.score)
from e 
join c
on e.emp_id=c.emp_id
join t
on c.course_id=t.course_id
where count(c.score)>0
order by t.course_name, c.score desc
limit 3
image
select e.emp_name,t.course_name ,avg(c.score)
from e 
join c
on e.emp_id=c.emp_id
join t
on c.course_id=t.course_id
where t.course_name in (‘数据库’,'java')
group by e.emp_name
having count(t.course_name)>1 

28 . 报错原因是什么?

image
1.数据库没有启动
2.socket文件位置不对

29. 数据库损坏?

物理损坏
逻辑损坏

30 . 从mysqldump 全备中获取 库和表的备份

1、获得表结构
# sed -e'/./{H;$!d;}' -e 'x;/CREATE TABLE `city`/!d;q'  full.sql>createtable.sql

2、获得INSERT INTO 语句,用于数据的恢复

# grep -i 'INSERT INTO `city`'  full.sqll >data.sql &

3.获取单库的备份

# sed -n '/^-- Current Database: `world`/,/^-- Current Database: `/p' all.sql >world.sql

31.面试题

image
1. 联合索引: idx(status , signal)
2. 查询条件调整  where status   and signal 
image
数据和类型 ,not null   ,注释 
image
SQL语句是数据DDL操作,是属于列的添加操作
直接执行时会产生表锁,对业务的影响较大,数据量大,业务量大时,对于业务影响较大。
所以我们推荐使用 pt-osc 工具来进行online DDL,减少对业务的影响
image
image
A->B架构转换
1. 主库写压力大,可以通过多级主从减轻主库的压力
B-》A架构转换
2.业务读多写少,通过多从库实现读写分离和读的负载均衡,另外可以配合MHA等架构进行高可用

32.报错

image.png

33 MySQL5.7中如何独立undo

innodb_max_undo_log_size = 128M
innodb_undo_log_truncate = ON
innodb_undo_logs = 128
innodb_undo_tablespaces = 3
innodb_purge_rseg_truncate_frequency = 10

34 mysqldump 导出时,去掉auto_increment

mysqldump -uroot -p -d test -S /tmp/mysql.sock | sed 's/AUTO_INCREMENT=[0-9]*\s*//g' > test.sql

35 MySQL 5.7 如何开启ssl功能

1.生成证书文件

[root@mycat1 ~]# mysql_ssl_rsa_setup  
[root@mycat1 ~]# ll /data/mysql/*.pem
-rw------- 1 root root 1675 Jun 10 16:00 /data/mysql/ca-key.pem
-rw-r--r-- 1 root root 1107 Jun 10 16:00 /data/mysql/ca.pem
-rw-r--r-- 1 root root 1107 Jun 10 16:00 /data/mysql/client-cert.pem
-rw------- 1 root root 1675 Jun 10 16:00 /data/mysql/client-key.pem
-rw------- 1 root root 1679 Jun 10 16:00 /data/mysql/private_key.pem
-rw-r--r-- 1 root root  451 Jun 10 16:00 /data/mysql/public_key.pem
-rw-r--r-- 1 root root 1107 Jun 10 16:00 /data/mysql/server-cert.pem
-rw------- 1 root root 1675 Jun 10 16:00 /data/mysql/server-key.pem

2.证书文件介绍

 ca-key.pem         #CA私钥
 ca.pem             #自签的CA证书,客户端连接也需要提供
 client-cert.pem    #客户端连接服务器端需要提供的证书文件
 client-key.pem     #客户端连接服务器端需要提供的私钥文件
 private_key.pem    #私钥/公钥对的私有成员
 public_key.pem     #私钥/公钥对的共有成员
 server-cert.pem    #服务器端证书文件
 server-key.pem     #服务器端私钥文件

3. 未完待续

36. 为什么很多人喜欢使用varchar(255)?

1. InnoDB存储引擎的表索引单一字段或前缀长度,最长是767字节(bytes)。
存中文时,utf8字符集,那么767/3=255,
如果是utf8mb4应当是,767/4=191.
2. 字符串长度值视实际数据长度,需占用 1 或 2 个字节存储。
  当实际数据长度 <= 255 时,varchar字段长度 = 1 + N
  当实际数据长度 > 255 时,varchar字段长度 = 2 + N

总结:其实是很多开发人员的一些习惯吧,但是往往不知道原因。所以呢带大家普及一下。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342