`

learning PHP开发者常犯的10个MySQL错误

 
阅读更多

 最近看到一篇文章:《PHP开发者常犯的10个MySQL错误》,发现文中不少内容陈旧,随着时间推移技术发展变化而变得不适用。为了防止误导新手,特本着与时俱进的精神写出此文,绝非对原文作者的不尊重。

  1.使用MyISAM而不是InnoDB

  完全错误,反驳理由:

  首先原文说MyISAM是默认使用的,而实际上到了MySQL 5.5.x,InnoDB已经成为了默认的表引擎。

  另外,简单的使用InnoDB不是解决所有问题的方法,盲目的使用甚至会使应用性能下降10%乃至40%。

  最佳方法还是针对具体业务具体处理,例如论坛中版块表,新闻分类表,各种码表等长时间不操作的表,还是要用性能优异的MyISAM引擎。

  而需要用到事务处理的例如用户、账目、流水等严格要求数据完整性和时序性的,则需要用InnoDB引擎,并且应用也要用好事务处理机制。当然,事务处理必然要带来大量的性能损耗,但是这在简单高并发应用上是必须的。

  最后,外键约束在公共web互联网应用上一般是不用的,因为他会严重影响性能。数据完整性还是靠程序员或者应用架构本身的健壮来维护。而正规的第三范式只是在企业内部MIS系统和12306这种网站上使用。

  2.使用PHP的mysql方法

  不完全错,但要酌情选用:

  mysqli固然好,但是不是所有的服务器都为PHP编译了mysqli的支持。

  当你的应用如果是能确定只用自己部署的服务器,而应用也是完全自己开发,则mysqli是最好的选择。

  但是一旦你的应用有可能部署在虚拟主机或者由其他人部署(例如分布式项目),还是老老实实使用mysql函数集吧,好好封装一下或者使用成熟框架杜绝sql注入。

  3.不过滤用户输入

  这一点不用说了,要么MagicQuote,要么选用成熟框架。sql注入老话题了。

  4.不使用UTF-8

  大部分情况下对,但也要认真考虑:

  要知道,一个UTF-8字符占3个字节,所以比GBK等其他编码的文件大33%。换句话说,相同的网页用UTF-8编码如果是100KB,那么换成GBK编码则只有66KB。所以即便你的PHP确定要用UTF-8,那么前端页面也要根据情况选择需要的编码。但是,如果PHP用UTF-8,前端模版是GBK,再加上模版引擎不强大,那么转码工作够你受的。所以尽可能的选用自己需要的编码,而不是简单的选择UTF-8了事。

  最后啰嗦一句:UTF-8下:strlen("我")=3,而GBK下:strlen("我")=2

  5.该用SQL的地方使用PHP

  同样酌情考虑:

  例如,有些人习惯在建表时,默认值填写CURRENT_TIMESTAMP,用来达到注册时间、发帖时间的效果。 或者在时间判断的SQL语句中,写类似SELECT x FROM tab1 WHERE regdate 正确做法是:不要使用MySQL的任何时间函数,而是在应用里计算时间。如果是分布式应用,一定要有时间服务器来统一管理时间。

  而文中说的一些MySQL数学函数 ,也是要慎用。因为在大型应用中,数据库的负担往往是最大的,而复杂的WHERE语句又是造成慢查询的元凶。所以,要把计算尽可能的放在廉价的、不影响全局稳定的应用服务器上,而不是核心数据库上。

  6.不优化查询

  这点也不用说了,大型应用上甚至不允许使用各种JOIN,哪怕生写两条查询,查回来在用PHP合并数据。

  7.使用错误的数据类型

  INT,TinyINT,VARCHAR,CHAR,TEXT这些字段类型的合理选用无可厚非。

  而Date、DateTime、TIMESTAMP这三种类型,在大型应用中是绝对不可以使用的,而是要用INT(10) UNSIGNED代替。

  一个是性能,另外就是应用中尤其是PHP对UNIX_TIMESTAMP时间戳的转化实在太方便了。用Date要输出各种时间格式反而麻烦。

  8.在SELECT查询中使用*

  共勉

  9.索引不足或者过度索引

  索引是必须的,但是如果索引都解决不了的查询,考虑memcache或者nosql解决方案吧。

  10.不备份

  这条是作者凑数么?

  11.另外:不考虑其他数据库

  这条相当正确。应用中不仅要针对应用选择其他数据库,甚至还要针对具体的业务类型,在同一套应用中并行使用多种数据库。哪怕不是数据库,而是其他各种缓存、内存存储等解决方案

分享到:
评论

相关推荐

    Learning PHP MySQL Javascript CSS and HTML5

    本书名为《Learning PHP, MySQL, JavaScript, CSS & HTML5》,主要针对初学者,全面介绍了与Web开发相关的几项核心技术。书中涉及的主题包括PHP服务器端脚本语言、MySQL数据库系统、客户端JavaScript脚本、CSS层叠...

    Learning PHP, MySQL, JavaScript, CSS & HTML5, 3rd Edition

    《Learning PHP, MySQL, JavaScript, CSS & HTML5, 3rd Edition》这本书全面介绍了构建现代动态网站所需的技术栈。通过学习这些技术,不仅可以掌握创建交互性强、功能丰富的网站的方法,还能深入了解每个工具的工作...

    Learning PHP and MySQL 2nd Edition

    ### 学习PHP与MySQL第二版 #### 一、概览 《学习PHP与MySQL第二版》是由Michele E. Davis与Jon A. Phillips共同编写的书籍,旨在为读者提供一套全面且实用的PHP与MySQL开发指南。本书不仅适合初学者作为入门教材,...

    [PHP.MySQL.JavaScript学习手册].(Learning.PHP.MySQL.and.JavaScript).Robin.Nixon

    学习手册].(Learning.PHP.MySQL.and.JavaScript).Robin.Nixon #### 描述:[PHP.MySQL.JavaScript学习手册].(Learning.PHP.MySQL.and.JavaScript).Robin.Nixon.文字版 #### 标签:PHP MySQL JavaScript #### 部分...

    Learning PHP,MySQL and JavaScript (5th)

    《Learning PHP, MySQL and JavaScript (5th)》是Robin Nixon撰写的一本关于前端和后端开发的综合教程书籍,它的最新版本为第五版。这本书专注于教授如何使用PHP,MySQL和JavaScript这三种技术来开发动态网站内容,...

    learning php-2.rar_Learning Php_php

    《Learning PHP》是针对Web开发者的PHP学习资料的第二部分,旨在深入理解并掌握PHP编程语言,以便在Web开发领域中高效工作。本压缩包包含的文件为“4_420741000680439844.pdf”,这可能是一个详细的章节或课程内容,...

    Learning_PHP_5.rar

    还有错误处理和调试技巧,这是每个开发者都需要掌握的技能。通过学习如何设置错误报告级别、使用错误日志和调试工具,可以有效地定位和解决问题,提高开发效率。 最后,书中可能会涵盖一些高级话题,如PHP的预定义...

    php和mysqlweb开发书籍推荐

    3. **《Learning PHP, MySQL & JavaScript》**:这本书不仅介绍了PHP和MySQL的基础知识,还加入了JavaScript的相关内容,帮助读者更好地理解现代Web应用开发的整体框架。 4. **《PHP Security》**:专门针对PHP...

    learning php-1.rar_Learning Php_php

    学习如何定义类,创建对象,以及使用接口和抽象类是进阶PHP开发者必须掌握的技能。 最后,理解PHP的session和cookie机制对于构建有状态的Web应用程序是必要的。它们允许在用户的不同请求之间保持信息,如登录状态。...

    Learning PHP设计模式 ([美]William Sanders) 中文pdf扫描版

    《Learning PHP设计模式》是由美国作家William Sanders撰写的一本面向初学者和中级PHP开发者的设计模式指南。这本书旨在帮助读者理解并应用设计模式这一强大的软件工程工具,以提高PHP编程的效率和代码质量。设计...

    learning php-3.rar_Learning Php_php

    10. **最佳实践和优化**:了解良好的编程习惯、代码组织、性能优化和调试方法是成为一名专业PHP开发者的必经之路。 通过“学习PHP-3”这份资料,读者可以深化对PHP的理解,提升Web开发技能,为构建高效、安全的Web...

    platform-e-learning.rar_Learning Php_e learning_e-learning

    平台e-learning是一个基于PHP构建的在线学习系统,旨在提供便捷、高效的远程教育解决方案。PHP是一种广泛使用的开源脚本语言,特别适合于Web开发,因此选择它作为后台技术栈来构建e-learning平台是相当常见的。 ...

    深入学习PHP,MySQL,javascript,CSS,html5

    本书《深入学习PHP,MySQL, JavaScript, CSS, HTML5》深入探讨了web开发的各个方面,包含前端和后端的设计与优化,以及数据库MySQL的详细讲解和优化方法。对于有志于提高Web开发技能的读者而言,这本书提供了非常...

    Learning PHP, MySQL and JavaScript with jQuery, CSS and HTML5

    这本书《Learning PHP, MySQL and JavaScript with jQuery, CSS and HTML5》是针对初学者介绍几种关键的Web开发语言的入门级教材。在Web开发领域,PHP、MySQL、JavaScript、jQuery、CSS和HTML5是非常重要的技术栈,...

Global site tag (gtag.js) - Google Analytics