MySQL 数据库由于性能高,成本低,可靠性好等优点,已经成为最流行的开源关系型数据库产品,广泛地被使用在互联网上的中小型网站中。并且随着MySQL的不断成熟,以及一些企业特性的加入,它也逐渐被用于更大规模的网站和应用系统中,如我们知道的维基百科,谷
MySQL 数据库由于性能高,成本低,可靠性好等优点,已经成为最流行的开源关系型数据库产品,广泛地被使用在互联网上的中小型网站中。并且随着MySQL的不断成熟,以及一些企业特性的加入,它也逐渐被用于更大规模的网站和应用系统中,如我们知道的维基百科,谷歌和facebook等。目前互联网上流行的网站架构方式LAMP,WNMP和LNMP,其中的“M”都是MySQL,这些都是免费或开放源代码软件,使用这种方式可以以很低的成本构建网站系统和其它应用。因此,MySQL越来越受到企业和个人开发者的厚爱。
MySQL是一个非常容易上手的数据库产品,很多人只要很短的时间就可以使用它。但是,作为一个有经验的的数据库应用程序的开发者写出来的sql查询语句和新手写出的sql语句在执行性能方面有巨大的差别,其根本的原因在于有经验的数据库应用开发者善于运用mysql的索引以及各种性能分析调优工具优化自己的查询。
但是,估计现在很多做开发的,对数据库优化都只是一个不是很清晰的概念或者一个全面的理解。我也是其中一个,虽然自己搞MySQL很长时间了。但大多数的情况下只是简单的使用sql语句,骨子里一直认为数据库应该是有专门的人士来搞,而这个人不应该是我这样的开发者。但是从实际上来看,这个角色经常是由开发人员来担任的。也就是说,作为一名日常“开发人员”,除了完成自己的本职工作外,最常重复的工作就是在生产环境中检查和优化运行的SQL语句。当MySQL软件安装、配置以及正常运行之后,监控数据库的性能问题就成为一项经常重复的工作。了解如何正确地截取有问题的SQL语句以及检查并做适当的调整,这已经成为一个专业技术人员的必备技能。
曾经一直以为使用一个alter语句在什么时候都可以的,可没想过要考虑什么因素,可刚看到《Effectove MySQL之SQL语句最优化》的第一章第二节就有这么一句话“在此期间,由于aletr语句是阻塞操作,因此所有为表添加和修改数据的额外请求都被阻塞了”。在这之前,一直都认为无论何时给一个表增加或者修改字段都可以的,根本没想过会影响其他的因素。《Effectove MySQL之SQL语句最优化》的第一章就讲了如何寻找缓慢的SQL语句,同时也介绍了几种用于优化语句的分析工具,包括EXPLAIN和SHOW CREATE TABLE。同时了解了应该重点关注能够识别性能问题的那些属性。同时知道优化SQL语句绝不仅仅是添加索引。这个虽然很早就知道,不过刚接触的SQL的都不太清楚。
下面我们看一下该书的目录图:
全书一共分为8章,每一章还有小结,全书很值得一读,学完了对mysql优化有一个进步的提升。本书的作者是Ronald Bradford,它写过一本《PHP+MySQL专家编程》,我没有看过中译本,因为它刚刚被引进,看过英文的电子版,写的还是不错的,因此,本书的内容还是很值得一看的。
该书是按照概念,实例,总结的模式来写的,比较符合学习知识的认知过程。该书不是很厚,只有短短的200页,这类书可以普遍归结到我们目前有的比如21天学通Java,什么24小时学通MySQL之类,但这本书比那些书要好很多,至少不是胡编乱造,抄写help吧,至少mysql的帮助也很少提供有关优化的方法,最多会给出一些概念罢了!
推荐指数:四星级
适合人群:有一定sql基础,想继续学习提供的人群
前面说了那么多,还是说说读完后的感想:老外写的书大都是比较贴近实际,比较务实的。 重点还是介绍了MySQL在调优过程中,常见的方法,以及适用的场景。
案例占据了书的一半版面,读者跟随书的介绍做一遍,一定会有不同程度的收获,属于开卷有益类的书籍
其实最有效的sql优化方法应该是:大处着眼,小处着手,通盘考虑,先看后动
具体的技术手段很多,索引,分区,配置等等,但都需要在深入理解问题以后,才能更好的解决问题
但本书还是存在的一些小毛病,就是在进行技术细节概念讲述的时候,并不直接给出概念的定义,而是跳跃式的讲解,很容易打断人的思路,我看的时候会时不时思想就开了小差,也许不太喜欢这类讲法吧!
还有就是没有指出案例是在什么环境下运行,windows还是linux还是别的什么环境下,因为,我在windows环境下运行了某些实例,发现居然有些不能运行,真是比较晕。
写的比较乱,不妥之处还忘大家海涵!

MySQL使用的是GPL许可证。1)GPL许可证允许自由使用、修改和分发MySQL,但修改后的分发需遵循GPL。2)商业许可证可避免公开修改,适合需要保密的商业应用。

选择InnoDB而不是MyISAM的情况包括:1)需要事务支持,2)高并发环境,3)需要高数据一致性;反之,选择MyISAM的情况包括:1)主要是读操作,2)不需要事务支持。InnoDB适合需要高数据一致性和事务处理的应用,如电商平台,而MyISAM适合读密集型且无需事务的应用,如博客系统。

在MySQL中,外键的作用是建立表与表之间的关系,确保数据的一致性和完整性。外键通过引用完整性检查和级联操作维护数据的有效性,使用时需注意性能优化和避免常见错误。

MySQL中有四种主要的索引类型:B-Tree索引、哈希索引、全文索引和空间索引。1.B-Tree索引适用于范围查询、排序和分组,适合在employees表的name列上创建。2.哈希索引适用于等值查询,适合在MEMORY存储引擎的hash_table表的id列上创建。3.全文索引用于文本搜索,适合在articles表的content列上创建。4.空间索引用于地理空间查询,适合在locations表的geom列上创建。

toCreateAnIndexinMysql,usethecReateIndexStatement.1)forasingLecolumn,使用“ createIndexIdx_lastNameEnemployees(lastName); 2)foracompositeIndex,使用“ createIndexIndexIndexIndexIndexDx_nameOmplayees(lastName,firstName,firstName);” 3)forauniqe instex,creationexexexexex,

MySQL和SQLite的主要区别在于设计理念和使用场景:1.MySQL适用于大型应用和企业级解决方案,支持高性能和高并发;2.SQLite适合移动应用和桌面软件,轻量级且易于嵌入。

MySQL中的索引是数据库表中一列或多列的有序结构,用于加速数据检索。1)索引通过减少扫描数据量提升查询速度。2)B-Tree索引利用平衡树结构,适合范围查询和排序。3)创建索引使用CREATEINDEX语句,如CREATEINDEXidx_customer_idONorders(customer_id)。4)复合索引可优化多列查询,如CREATEINDEXidx_customer_orderONorders(customer_id,order_date)。5)使用EXPLAIN分析查询计划,避

在MySQL中使用事务可以确保数据一致性。1)通过STARTTRANSACTION开始事务,执行SQL操作后用COMMIT提交或ROLLBACK回滚。2)使用SAVEPOINT可以设置保存点,允许部分回滚。3)性能优化建议包括缩短事务时间、避免大规模查询和合理使用隔离级别。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

WebStorm Mac版
好用的JavaScript开发工具

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

记事本++7.3.1
好用且免费的代码编辑器