MySQL接続方法比較

データベース関連

一覧

 状態:-  閲覧数:2,326  投稿日:2014-09-30  更新日:2015-07-15  
MySQL接続方法比較
・MySQLi / オブジェクト指向型、手続き型
・PDO
・MDB2
クラス メソッド メリット デメリット 備考
MySQLi オブジェクト指向型 / mysqli::__construct - - ※コンストラクタにつき、実際に記述する内容は、new mysqli
MySQLi 手続き型 / mysqli_connect - - MySQLバージョン> 4.1.3
- mysql_connect データベース固有のネイティブドライバ。速度が一番早い。データベース特有の機能を使用可能 用意されている関数は他のデータベース用として共通化されているわけではない(MySQL以外では使用不可)。今後、他のDBを使用する可能性がある場合には、避けた方が良い PHP 5.5.0 で非推奨。MySQLに特化したネイティブ関数。スクリプトの終了とともに自動的に接続が解除される
- mysql_pconnect - - PHP 5.5.0 で非推奨。MySQLに特化したネイティブ関数。スクリプト終了後も永続的に接続は確立されたままとなる。そのため、不特定多数のアクセスを受け入れると負荷が非常に大きくなってしまうが、特定少数であれば接続待ち時間のロスを大きく減らすことができる
PDO PDO::__construct PHPスクリプトとネイティブドライバの組合せではなく、PHP Extension(PHP拡張)として利用できるため、PEAR::MDB2より速いとされる。
元々はPECLで書かれたラッパのため、PHPで書かれたPEARのラッパより速度面で有利。
※ PECL(ピクル、PHP Extension Community Library)は、PHPで利用できる拡張ライブラリ(パッケージ)を提供しているサービス。PECLで提供されるライブラリはCで記述されているた め、PHPで記述されたPEARのライブラリよりも高速に動作
レンタルサーバによっては対応していない可能性もあり(モジュールを使えるようにしてあるかの問題) ※コンストラクタにつき、実際に記述する内容は、new PDO。PDOは、「PHP Data Objects」の略
- MDB2::connect どのデータベースでも利用可能 共通のAPIを提供している部分がPHPスクリプトで書かれているため、実効速度が遅い PHPで用意されている、多くのネイティブなデータベースアクセスのための関数(ネイティブドライバ)をPHPスクリプトでまとめ(ラッピングし)、共通のAPIを提供しているもの。
PHPスクリプトとネイティブドライバの組み合わせ。
複数のDBを同じ操作で使えるようにしたDB接続関数のラッパ。※MDBは、MDB2の前バージョン


特徴

 閲覧数:487 投稿日:2016-03-14 更新日:2016-03-14 
mysqli::real_escape_string と mysqli_real_escape_string は、引数の数が異なる

mysqli_escape_string
・mysqli_real_escape_string() のエイリアス


オブジェクト関係マッピング

MySQL Native Driver

コメント投稿(ログインが必要)



週間人気ページランキング / 5-25 → 5-31
順位 ページタイトル抜粋 アクセス数
1 PHPにおけるメソッドのオーバーライドについて /「引数の数や型は、親クラスのメソッドと完全に一致していなければなりません。」とは具体的にどういう意味ですか? 5
2 http_build_queryとは? / 構文 /パラメータ 4
2 Parse error: syntax error, unexpected 'public' (T_PUBLIC) | Parse error(エラーメッセージ) 4
3 htmlspecialchars / htmlentities / addslashes / mysql_real_escape_string / mysqli_real_escape_string | セキュリティ 3
3 ブラウザを閉じたらセッションデータはどうなるの? | セッション 3
3 インポートするデータを受信できませんでした。ファイル名が送信されていないか、ファイルサイズが PHP の設定で許可された最大値を超えています。FAQ 1.16 をご覧ください | エラーメッセージ 3
4 セッション管理が必要な理由は、HTTPプロトコルには状態を保持する機能がないため | セッション 2
4 $this | クラスとオブジェクト 2
4 Fatal error(エラーメッセージ) カテゴリー 2
4 PHPで定数を定義する方法は2種類ある / 配列定数の定義 2
4 Warning: session_write_close(): Failed to write session data (user) | Warning(エラーメッセージ) 2
4 ( ! ) Warning: Declaration of xxxx should be compatible with | エラーメッセージ 2
4 ( ! ) Fatal error: Uncaught Abraham\TwitterOAuth\TwitterOAuthException: {"errors":[{"code":32,"message":"Could not authenticate you."}]} | Fatal error(エラーメッセージ) 2
4 Fatal error: require_once(): Failed opening required 'PEAR.php' | Fatal error(エラーメッセージ) 2
4 Fatal error: Uncaught Wrench\Exception\HandshakeException: No accept header receieved on handshake response in ★★★ headless-chromium-php/vendor/wrench/wrench/lib/Wrench/Protocol/Protocol.php | エラーメッセージ 2
4 Fatal error: Uncaught Error: Call to a member function modify() on string | Fatal error(エラーメッセージ) 2
4 可変変数 | 変数 2
4 クロージャ | 関数 2
4 Fatal error: Access level to ▲::$△ must be protected (as in class ●) or weaker | Fatal error(エラーメッセージ) 2
5 mixed | 型 1
2025/6/1 1:01 更新