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

最近看到一篇文章:《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. 另外:不考虑其他数据库
这条相当正确。应用中不仅要针对应用选择其他数据库,甚至还要针对具体的业务类型,在同一套应用中并行使用多种数据库。哪怕不是数据库,而是其他各种缓存、内存存储等解决方案。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

MySQL 8.4 (2024 年時点の最新の LTS リリース) で導入された主な変更の 1 つは、「MySQL Native Password」プラグインがデフォルトで有効ではなくなったことです。さらに、MySQL 9.0 ではこのプラグインが完全に削除されています。 この変更は PHP および他のアプリに影響します

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

このチュートリアルでは、PHPを使用してXMLドキュメントを効率的に処理する方法を示しています。 XML(拡張可能なマークアップ言語)は、人間の読みやすさとマシン解析の両方に合わせて設計された多用途のテキストベースのマークアップ言語です。一般的にデータストレージに使用されます

文字列は、文字、数字、シンボルを含む一連の文字です。このチュートリアルでは、さまざまな方法を使用してPHPの特定の文字列内の母音の数を計算する方法を学びます。英語の母音は、a、e、i、o、u、そしてそれらは大文字または小文字である可能性があります。 母音とは何ですか? 母音は、特定の発音を表すアルファベットのある文字です。大文字と小文字など、英語には5つの母音があります。 a、e、i、o、u 例1 入力:string = "tutorialspoint" 出力:6 説明する 文字列「TutorialSpoint」の母音は、u、o、i、a、o、iです。合計で6元があります

あなたが経験豊富な PHP 開発者であれば、すでにそこにいて、すでにそれを行っていると感じているかもしれません。あなたは、運用を達成するために、かなりの数のアプリケーションを開発し、数百万行のコードをデバッグし、大量のスクリプトを微調整してきました。

CMSはコンテンツマネジメントシステムの略称です。これは、ユーザーが高度な技術知識を必要とせずにデジタル コンテンツを作成、管理、変更できるようにするソフトウェア アプリケーションまたはプラットフォームです。 CMS を使用すると、ユーザーはコンテンツを簡単に作成および整理できます

配列は、プログラミングのデータを処理するために使用される線形データ構造です。アレイを処理している場合は、既存の配列に新しい要素を追加する必要があります。この記事では、各方法のコード例、出力、時間と空間の複雑さ分析を使用して、PHPの配列の最後に要素を追加するいくつかの方法について説明します。 アレイに要素を追加するさまざまな方法は次のとおりです。 四角い括弧を使用します[] PHPでは、配列の最後に要素を追加する方法は、四角い括弧[]を使用することです。この構文は、単一の要素のみを追加する場合にのみ機能します。以下は構文です。 $ array [] = value; 例
