登录
首页 >  数据库 >  MySQL

《MySQL必知必会》读书笔记

来源:SegmentFault

时间:2023-02-24 17:08:53 455浏览 收藏

本篇文章向大家介绍《《MySQL必知必会》读书笔记》,主要包括MySQL,具有一定的参考价值,需要的朋友可以参考一下。

《MySQL必知必会》读书笔记

资源链接:

@Test
public void test() {

    Map map = new HashMap();
    map.put(" a1", "test1");
    map.put("a3", "test3");
    map.put("a2", "test2");
    System.out.println(map.get("a1"));
}/*运行结果:
null

*/

​ 不知道碰到这种BUG的人有多痛苦,个人没有碰到过,但是曾经给同事排查问题的发现了类似的情况,当然不是这么明显的错,而是由于前端传递的时候,json当中的key前面多了一个空格,也是因为这个空格,导致花了好几个小时才排查出来!这里希望读者引以为戒,在编写类似代码时候严格检查有没有手贱多敲空格。

and和or的优先级问题:

​ 有时候我们会写出这样的sql:

select * from t_user where name = 'xxx' or age > 18 and email like '@qq.com'

​ 这里根据优先级的就近匹配原则,百分之百的会出现意想不到的情况,因为此时mysql会误认为是下面这样的情况,进行查询之后,数据肯定和我们预想的or条件不一致了:

select * from t_user where name = 'xxx' or (age > 18 and email like '@qq.com')

​ 要修复这段程序很简单就是把or查询的条件包裹起来:

select * from t_user where (name = 'xxx' or age > 18) and email like '@qq.com'

​ 所以不管是编程语言还是sql,都需要小心这种操作符优先级带来的莫名其妙的问题。

不能没有的where条件

​ 不论是select,update,insert,delete那个操作,最应该关注的是有没有where条件,可能有人会觉得select影响会稍微小一些?

​ 大错特错,加入select一张全表特别是

TRUNCATE table task_log

​ 现实情况下其实是完全不推荐使用delete去大批量的删除数据,很容易造成资源占用和线程的阻塞(涉及数据结构和底层设计的原理,原因很复杂不做扩展)。也有一些线上库是禁止DELETE的或者在设计的层面上引入 假删除,这里也不做过多扩展,总之DELETE操作能少用就少用

建表的时候尽量使用not null

​ 又是这个深恶痛绝的null,有些数据表的设计会默认给一个值,哪怕他确实没有任何数据也要填充一个''空字符串进去,至于原因这里忘了,总之是null对于索引有很重要的影响,容易让索引失效?总之,数据最好都有意义,没有意义就给个默认值是最好的

总结

​ 如果没有mysql或者sql基础,这本书算是最值得推荐的入门书籍,没有之一,个人当年学习数据库是用的一些垃圾培训机构的书,写的又啰嗦还全是图片,后面跑去看培训机构的视频才真正看懂......

写到最后

​ 写笔记的时候回过头又看了一遍,确实是一本值得推荐的好书,好拿读起来也十分的轻松。

本篇关于《《MySQL必知必会》读书笔记》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于数据库的相关知识,请关注golang学习网公众号!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表