Mysql慢查询、主从复制,Github标星25K+超火的Java实战项目

索引失效

如果索引了多列,要遵守最左前缀法则。指的是查询从索引的最左前列开始并且不跳过索引中的列

%like前模糊也会导致索引失效,但like%后模糊可以使用索引

不等于(!= 或者<>)索引失效

is not null无法使用索引,is null可使用索引

类型转换导致索引失效(字段是字符串)

Join

  1. left join 时,选择小表作为驱动表,大表作为被驱动表

  2. inner join 时,mysql会自动将小结果集的表选为驱动表。选择相信mysql优化策略。

  3. 能够直接多表关联的尽量直接关联,不用子查询

用explain出现时,表示没走索引

慢查询

默认关闭,需要手动打开

查看慢查询   可以看到开没开起与日志目录

SHOW VARIABLES LIKE ‘%slow_query_log%’;

2.  开启:set global slow_query_log=1; 只对窗口生效,重启服务失效  默认10s

SET GLOBAL long_query_time=0.1;  设置慢查询时间

对当前会话连接立即生效,对其他客户端无效。

SET SESSION long_query_time=0.1; #session可省略

查询当前系统中有多少条慢查询记录或者直接看慢查询日志

/var/lib/mysql/localhost-slow.log

SHOW GLOBAL STATUS LIKE ‘%Slow_queries%’; 查看慢日志

mysqldumpslow -s r -t 10 /var/lib/mysql/localhost-slow.log 查询慢的sq

视图

将sql封装为一个虚拟的表,这个虚拟的表只保存sql逻辑,不保存查询结果

创建语句

CREATE VIEW view_name

AS SELECT * FROM …

查询

select * from view_name

更新

CREATE OR REPLACE VIEW view_name

AS SELECT … FROM …

删除

drop view view_name;

mysql 视图会随着表中的数据变化而动态变化

主从复制

Ø slave会从master读取binlog来进行数据同步

Ø MySQL复制三步骤:

1 master将写操作记录到二进制日志(binary log)。这些记录过程叫做二进制日志事件,binary log events;

2 slave将master的binary log events拷贝到它的中继日志(relay log);

3 slave重做中继日志中的事件,将改变应用到自己的数据库中。 MySQL复制是异步的且串行化的,而且重启后从接入点开始复制。

复制的最大问题(延时

复制的基本原则

Ø 每个slave只有一个master

Ø 每个slave只能有一个唯一的服务器ID

Ø 每个master可以有多个salve

使用

在虚拟机中创建2台虚拟机,

在主机打开配置文件,加入

#主服务器唯一ID

server-id=1

#启用二进制日志

log-bin=mysql-bin

#设置不要复制的数据库(可设置多个)

binlog-ignore-db=mysql

binlog-ignore-db=infomation_schema

#设置需要复制的数据库

binlog-do-db=mytestdb

#设置logbin格式  默认的

binlog_format=STATEMENT

logbin格式:

  • binlog_format=STATEMENT(默认):数据操作的时间,同步时不一致,可以用java代码同步时间

  • binlog_format=ROW:批量数据操作时,效率低

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
img

总结:心得体会

既然选择这个行业,选择了做一个程序员,也就明白只有不断学习,积累实战经验才有资格往上走,拿高薪,为自己,为父母,为以后的家能有一定的经济保障。

学习时间都是自己挤出来的,短时间或许很难看到效果,一旦坚持下来了,必然会有所改变。不如好好想想自己为什么想进入这个行业,给自己内心一个答案。

面试大厂,最重要的就是夯实的基础,不然面试官随便一问你就凉了;其次会问一些技术原理,还会看你对知识掌握的广度,最重要的还是你的思路,这是面试官比较看重的。

最后,上面这些大厂面试真题都是非常好的学习资料,通过这些面试真题能够看看自己对技术知识掌握的大概情况,从而能够给自己定一个学习方向。包括上面分享到的学习指南,你都可以从学习指南里理顺学习路线,避免低效学习。

大厂Java架构核心笔记(适合中高级程序员阅读):

,不然面试官随便一问你就凉了;其次会问一些技术原理,还会看你对知识掌握的广度,最重要的还是你的思路,这是面试官比较看重的。

最后,上面这些大厂面试真题都是非常好的学习资料,通过这些面试真题能够看看自己对技术知识掌握的大概情况,从而能够给自己定一个学习方向。包括上面分享到的学习指南,你都可以从学习指南里理顺学习路线,避免低效学习。

大厂Java架构核心笔记(适合中高级程序员阅读):

[外链图片转存中…(img-QkvnOwb4-1712098791681)]

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值