`
再逢山水
  • 浏览: 156306 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

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

    博客分类:
  • LAMP
 
阅读更多

数据库是WEB大多数应用开发的基础。如果你是用PHP,那么大多数据库用的是MYSQL也是LAMP架构的重要部分。

PHP看起来很简单,一个初学者也可以几个小时内就能开始写函数了。但是建立一个稳定、可靠的数据库确需要时间和经验。下面就是一些这样的经验,不仅仅是MYSQL,其他数据库也一样可以参考。

1、使用MyISAM而不是InnoDB

MySQL有很多的数据库引擎,单一般也就用MyISAM和InnoDB。

MyISAM是默认使用的。但是除非你是建立一个非常简单的数据库或者只是实验性的,那么到大多数时候这个选择是错误的。MyISAM不支持外键的约束,这是保证数据完整性的精华所在啊。另外,MyISAM会在添加或者更新数据的时候将整个表锁住,这在以后的扩展性能上会有很大的问题。

解决办法很简单:使用InnoDB。

2、使用PHP的mysql方法

PHP从一开始就提供了MySQL的函数库。很多程序都依赖于mysql_connect、mysql_query、mysql_fetch_assoc等等,但是PHP手册中建议:

如果你使用的MySQL版本在4.1.3之后,那么强烈建议使用mysqli扩展。

mysqli,或者说MySQL的高级扩展,有一些优点:

有面向对象的接口

prepared statements(预处理语句,可以有效防止SQL-注入攻击,还能提高性能)

支持多种语句和事务

另外,如果你想支持多数据库那么应该考虑一下PDO。

3、不过滤用户输入

应该是:永远别相信用户的输入。用后端的PHP来校验过滤每一条输入的信息,不要相信Javascript。像下面这样的SQL语句很容易就会被攻击:

 

  $username = $_POST["name"];

  $password = $_POST["password"];

  $sql = "SELECT userid FROM usertable WHERE username='$username'AND password='$password';"; // run query...

 

这样的代码,如果用户输入”admin’;”那么,就相当于下面这条了:

 

SELECT userid FROM usertable WHERE username='admin';

 

这样入侵者就能不输入密码,就通过admin身份登录了。

4、不使用UTF-8

那些英美国家的用户,很少考虑语言的问题,这样就造成很多产品就不能在其他地方通用。还有一些GBK编码的,也会有很多的麻烦。

UTF-8解决了很多国际化的问题。虽然PHP6才能比较完美的解决这个问题,但是也不妨碍你将MySQL的字符集设置为UTF-8。

5、该用SQL的地方使用PHP

如果你刚接触MySQL,有时候解决问题的时候可能会先考虑使用你熟悉的语言来解决。这样就可能造成一些浪费和性能比较差的情况。比如:计算平均值的时候不适用MySQL原生的AVG()方法,而是用PHP将所有值循环一遍然后累加计算平均值。

另外还要注意SQL查询中的PHP循环。通常,在取得所有结果之后再用PHP来循环的效率更高。

一般在处理大量数据的时候使用强有力的数据库方法,更能提高效率。

6、不优化查询

99%的PHP性能问题都是数据库造成的,一条糟糕的SQL语句可能让你的整个程序都非常慢。MySQL的EXPLAIN statement,Query Profiler,many other tools的这些工具可以帮你找出那些调皮的SELECT。

7、使用错误的数据类型

MySQL提供一系列数字、字符串、时间等的数据类型。如果你想存储日期,那么就是用DATE或者DATETIME类型,使用整形或者字符串会让事情更加复杂。

有时候你想用自己定义的数据类型,例如,使用字符串存储序列化的PHP对象。数据库的添加可能很容易,但是这样的话,MySQL就会变得很笨重,而且以后可能导致一些问题。

8、在SELECT查询中使用*

不要使用*在表中返回所有的字段,这会非常的慢。你只需要取出你需要的数据字段。如果你需要取出所有的字段,那么可能你的表需要更改了。

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

一般来说,应该索引出现在SELECT语句中WHERE后面所有的字段。

例如,假如我们的用户表有一个数字的ID(主键)和email地址。登录之后,MySQL应该通过email找到相应的ID。通过索引,MySQL可以通过搜索算法很快的定位email。如果没有索引,MySQL就需要检查每一项记录直到找到。

这样的话,你可能想给每一个字段都添加索引,但是这样做的后果就是在你更新或者添加的时候,索引就会重新做一遍,当数据量大的时候,就会有性能问题。所以,只在需要的字段做索引。

10、不备份

也许不常发生,但是数据库损毁,硬盘坏了、服务停止等等,这些都会对数据造成灾难性的破坏。所以你一定要确保自动备份数据或者保存副本。

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

MySQL可能是PHP用的最多的数据库了,但是也不是唯一的选择。 PostgreSQL和Firebird也是竞争者,他们都开源,而且不被某些公司所控制。微软提供SQL Server Express,Oracle有10g Express,这些企业级的也有免费版。SQLite对于一些小型的或者嵌入式应用来说也是不错的选择。

分享到:
评论

相关推荐

    PHP开发者最常犯的11个MySQL错误编程小技巧共4页

    本篇内容将详细解析PHP开发者最常犯的11个MySQL编程错误,并提供相应的解决小技巧。 1. **未使用预处理语句**: 预处理语句可以防止SQL注入攻击,通过绑定参数来执行查询。不使用预处理可能导致恶意用户通过输入...

    PHP开发者常犯的10个MySQL错误更正剖析

    本文将基于文章《PHP开发者常犯的10个MySQL错误》的更正与剖析,探讨这些错误并提供一些与时俱进的解决方案。 首先,关于数据库引擎的选择,MyISAM与InnoDB一直是开发者争论的焦点。在过去,MyISAM确实是MySQL的...

    总结PHP程序员最常犯的11个MySQL错误.docx

    【PHP程序员常犯的MySQL错误】: 1. **选择错误的存储引擎**:在MySQL中,MyISAM和InnoDB是最常见的引擎。然而,MyISAM不支持事务处理和外键约束,对于需要数据完整性和高并发的应用来说,选择InnoDB更为明智。 2....

    查询mysql错误信息、及js错误信息

    本文将详细讲解如何查询MySQL错误信息以及JavaScript错误信息,并提供相关知识点。 首先,我们来了解一下如何查询MySQL错误信息。MySQL在执行SQL语句时,如果遇到语法错误、权限问题或逻辑错误等,会返回一个错误...

    Apache+mysql+php

    在IT领域,"Apache+MySQL+PHP"是一个经典的Web开发环境组合,被称为LAMP(Linux, Apache, MySQL, PHP)的Windows版本,这里为WAMP(Windows, Apache, MySQL, PHP)。这个组合提供了强大的功能,使得开发者能够在本地...

    php_mysql.dll ( for PHP 5.2.11 MySQL 5.1.40 )

    《PHP与MySQL数据库连接:...了解这些基础知识,以及如何正确处理和解决这些问题,对于任何PHP开发者来说都是至关重要的。同时,随着技术的发展,开发者应不断学习新的连接方式和最佳实践,以适应不断变化的开发环境。

    php+mysql学生信息管理系统。基于php+mysql 一个简

    总的来说,“php+mysql学生信息管理系统”是一个典型的Web应用案例,它涵盖了Web开发的基础知识,对于提升开发者在数据库管理和Web交互方面的技能有着显著的帮助。通过分析和实践这个系统,不仅可以掌握PHP编程和...

    php_pdo_mysql.dll_dll_PDO_MYSQL_php_

    标题 "php_pdo_mysql.dll_dll_PDO_MYSQL_php_" 暗示了我们正在讨论的是PHP的一个扩展,即PDO_MYSQL,它是一个用于MySQL数据库连接的PHP数据对象(PDO)驱动。PDO_MYSQL允许PHP应用程序使用PDO接口与MySQL服务器进行...

    原创的一个PHP+MYSQL论坛

    通过分析和研究这个"原创的PHP+MYSQL论坛",开发者和学习者可以深入理解Web应用程序的开发流程,提升PHP和MySQL的实际运用能力,同时也能接触到Web安全、用户体验等多方面知识。对于希望从事Web开发的人来说,这是一...

    PHP+MYSQL php网站环境配置,服务器php网站搭建

    总的来说,这个压缩包提供的工具简化了在IIS上部署PHP和MySQL网站的过程,使得非专业开发者也能快速搭建Web环境。不过,为了确保网站的安全性和稳定性,还需要了解并遵循最佳实践,定期进行维护和更新。

    PHP6与MySQL5-php6.rar

    2. **更好的错误处理**:引入了更严格的错误处理机制,有助于开发者编写更加健壮的代码。 3. **命名空间**:类似于其他面向对象的语言,PHP6引入了命名空间,用于组织和管理类库,避免命名冲突。 4. **改进的类型...

    PHP_MySQL.tar.gz_PHP + mysql_mysql 教程_mysql教程_php_php mysql

    4. 错误处理:PHP提供了错误报告机制,帮助开发者调试代码,而MySQL则有事务处理机制,确保数据的一致性。 四、PHP+MySQL的应用场景 1. 动态网站:如新闻发布系统、论坛、电子商务平台等,PHP用于处理用户请求,...

    PHP+mysql 网站源码

    - 数据库模型:MySQL 基于关系模型,用表格(表)来存储数据,每个表有多个列(字段)和行(记录)。 - SQL 语言:用于操作 MySQL 的标准语言,包括 SELECT、INSERT、UPDATE、DELETE 等命令。 - 数据库设计:遵循...

    PHP+MYSQL网站

    【PHP+MYSQL网站】是一个基于PHP编程语言和MySQL数据库构建的企业级基础网站。这个网站的构建是互联网开发中的常见实践,因为PHP与MySQL的组合是Web开发中的经典搭档,提供了高效、灵活且可扩展的解决方案。 PHP...

    php+mysql 新闻发布系统

    【PHP+MySQL 新闻发布系统】是一个基于PHP编程语言和MySQL数据库技术开发的动态网站系统。这个系统的主要功能包括新闻的展示、分类管理和后台管理,为用户提供了一个方便、高效的新闻发布和管理平台。 首先,让我们...

    PHP+MySQL编程实例:PHP+MySQL编程实例.rar

    在IT行业中,PHP和MySQL是两个非常重要的技术,它们共同构建了互联网上众多动态网站的基础。PHP是一种服务器端脚本语言,广泛用于网页开发,而MySQL则是一款关系型数据库管理系统,用于存储和管理网站的数据。...

    php整合mysql文档

    在安装过程中,可能需要先停止MySQL服务,以避免出现冲突或错误。 #### 步骤4:启动MySQL服务 ``` shell> /etc/rc.d/init.d/mysqld start ``` 安装完成后,重新启动MySQL服务,确保MySQL服务正常运行。 #### 步骤5...

Global site tag (gtag.js) - Google Analytics