mysql数据库性能优化(迅雷网络1.pptVIP

  1. 1、本文档共25页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
mysql数据库性能优化(迅雷网络1

创建name列的索引 转换domain字段内容 MySQL数据库的 性能优化 数据库性能优化的必要性 应用程序对数据库操作的重视 网页对数据复杂逻辑的更多要求 网页对数据查询速度的更多要求 能以较少的工作量达到整体性能的较大提升 避免应用系统效率低下、资源严重浪费 MySQL数据库优化的几个方面 硬件的优化 操作系统的优化 MySQL系统配置的优化 MySQL语句的优化 MySQL索引的优化 MySQL表结构的优化 硬件的优化 如果需要庞大的数据库表(2G),应考虑使用64位的硬件结构 对大数据库,优化的次序一般是RAM、快速硬盘、CPU能力 对于数据库存放在一个专用服务器的系统,应该考虑1G的以太网 操作系统的优化 不要交换区,增加更多的内存 增加系统和MySQL服务器的打开文件数量 增加系统的进程和线程数量 使用支持大文件的文件系统(如:Solaris) MySQL系统配置的优化 MySQL编译安装参数的优化 MySQL服务器参数的调整优化,通过修改 /etc/f (my.ini)文件 优化服务器配置参数对于InnoDB表尤为重要 MySQL语句的优化 1、IS NULL 与 IS NOT NULL 不能用null作索引 如果某列存在空值,即使对该列建索引也不会提高性能 任何在where子句中使用is null或is not null的语句,优化器是不允许使用索引的 MySQL语句的优化 2、使用连接(JOIN)来代替子查询(Sub-Queries) MySQL从4.1开始支持SQL的子查询,使用子查询可以一次性的完成很多逻辑上需要多个步骤才能完成的SQL操作,同时也可以避免事务或者表锁死,如下所示: SELECT * FROM customerinfo WHERE CustomerID NOT in (SELECT CustomerID FROM salesinfo ) 如果使用连接(JOIN).. 来完成这个查询工作,速度将会快很多。尤其是当salesinfo表中对CustomerID建有索引的话,性能将会更好,查询如下: SELECT * FROM customerinfo LEFT JOIN salesinfoON customerinfo.CustomerID=salesinfo.CustomerID WHERE salesinfo.CustomerID IS NULL 连接(JOIN).. 之所以更有效率一些,是因为 MySQL不需要在内存中创建临时表来完成这个逻辑上的需要两个步骤的查询工作。 MySQL语句的优化 3、使用联合(UNION)来代替手动创建的临时表 可以把需要使用临时表的两条或更多的 SELECT 查询合并的一个查询中,在客户端的查询会话结束的时候,临时表会被自动删除,从而保证数据库整齐、高效,如下所示: SELECT Name, Phone FROM client UNION SELECT Name, BirthDate FROM author UNION SELECT Name, Supplier FROM product MySQL语句的优化 4、使用事务处理繁琐SQL语句的操作 当需要用到一系列的语句来完成某种工作时,应该使用事务;它的作用是:要么语句块中每条语句都操作成功,要么都失败。如下所示: BEGIN; INSERT INTO salesinfo SET CustomerID=14; UPDATE inventory SET Quantity=11 WHERE item=book; COMMIT; 用ROLLBACK命令就可以把数据库恢复到BEGIN开始之前的状态。事务的另一个重要作用是当多个用户同时使用相同的数据源时,它可以利用锁定数据库的方法来为用户提供一种安全的访问方式,这样可以保证用户的操作不被其它的用户所干扰。 MySQL语句的优化 5、使用锁定表(LOCK TABLE)的操作 事务因为它的独占性,有时会影响数据库的性能,尤其是在较大的应用系统中。有些情况下我们可以通过锁定表的方法来获得更好的性能。如下所示: LOCK TABLE inventory WRITE SELECT Quantity FROM inventory WHERE Item=book; ... UPDATE inventory SET Quantity=11 WHERE Item=book;

文档评论(0)

celkhn0303 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档