ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
PHPのDB接続方法です。
子ページからDB接続方法を選択して下さい。
※PDO以外の接続方法をご存知の方、項目の作成をお願いします。
主なDB接続方法
| 方法 | 特徴 | 状況 |
|---|---|---|
| PDO (PHP Data Objects) | DB抽象化レイヤ。MySQL/PostgreSQL/SQLite等を統一APIで扱う | 現在の標準・推奨 |
| mysqli | MySQL専用。手続き型/オブジェクト指向の2インターフェース | 現役だがMySQL固定 |
| mysql_* | 古いMySQL関数群 | PHP 7.0で削除済み |
| pg_* | PostgreSQL専用関数群 | 現役 |
| oci8 | Oracle専用 | 現役 |
| sqlsrv | SQL Server専用(Microsoft製) | 現役 |
| 各種ORM(Eloquent / Doctrine等) | PDOをラップしたORM | フレームワーク経由 |
本ページの子ページ
- PDO(PHP Data Objects) — プリペアドステートメント対応の標準DB接続API
PDOを推奨する理由
- SQLインジェクション対策が容易: プリペアドステートメントを標準サポート
- DBエンジン非依存: 同じコードでMySQL/PostgreSQL/SQLiteを切替可能
- 例外処理が統一的:
PDO::ATTR_ERRMODEで例外モード - トランザクションサポート
- 現役メンテナンス
PDOによる最小接続例
|
$dsn = 'mysql:host=127.0.0.1;dbname=mydb;charset=utf8mb4'; |
各DBへの接続DSN
| DB | DSN例 |
|---|---|
| MySQL / MariaDB | mysql:host=127.0.0.1;dbname=mydb;charset=utf8mb4 |
| PostgreSQL | pgsql:host=127.0.0.1;dbname=mydb |
| SQLite | sqlite:/path/to/db.sqlite |
| SQL Server | sqlsrv:Server=localhost;Database=mydb |
セキュリティの基本
- 絶対にSQLを文字列連結しない。必ずプリペアド + バインド
- 本番でエラー文字列にDB情報・SQLが含まれないようにする(エラーログは別チャネルへ)
- DBユーザーは必要最小権限で(本番DELETE権限を持つ接続を業務処理に使わない)
- パスワードは
.envや Secret Manager 経由、コード直書き禁止
注意点
- PDO::ATTR_EMULATE_PREPARES = false を推奨。エミュレーションを切ると真のプリペアドが使われる
- charset=utf8mb4 をDSNで指定(utf8では絵文字が文字化けする)
- 例外モードで Driver-specific例外(
PDOException::getCode())を活用
関連
- 親カテゴリ: 文法 (PHP)
- PDO詳細: PDO(PHP Data Objects)
- Laravelの場合: データベースの設定
- SQL本体: SQL
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- Laravel キャッシュクリア完全ガイド(cache:clear / config:clear / 2026-05-18 07:42:07
- プロジェクトの作成と削除 2026-05-18 07:42:07
- インストール直後にNetbeansが反応しない 2026-05-18 07:42:07
- 動画やチャンネルの検索 2026-05-18 07:42:07
- APIキー取得方法 2026-05-18 07:42:07
- チャンネル情報の取得 2026-05-18 07:42:07
- API 入門 — Web API(REST / GraphQL / gRPC / 2026-05-18 07:42:07
- インストール(eclipseプラグイン) 2026-05-18 07:42:07
- Laravel「Dotenv values containing spaces must be surrounded 2026-05-18 07:42:07
- エラー一覧 2026-05-18 07:42:07
- curl: (51) SSL: certificate subject name '~' does not match 2026-05-18 07:42:07
- インストール方法(Windows版) 2026-05-18 07:42:07
- JSONから配列に変換 2026-05-18 07:42:07
- 処理を一定時間待つ 2026-05-18 07:42:07
- A non well formed numeric value encountered 2026-05-18 07:42:07
コメントを削除してもよろしいでしょうか?