ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
JavaのDB接続の記事です。JDBC(Java Database Connectivity)という標準APIを通じて、MySQL/PostgreSQL/Oracle/SQL Server等の各種RDBに接続できます。
JDBC接続の基本
JavaではJDBC APIがDB接続の標準。各DBベンダーが提供するJDBCドライバ(jarファイル)をクラスパスに追加し、共通のAPIで操作します。
必要なもの
| DB | JDBCドライバ |
|---|---|
| MySQL / MariaDB | mysql-connector-j、mariadb-java-client |
| PostgreSQL | postgresql |
| Oracle | ojdbc |
| SQL Server | mssql-jdbc |
| DB2 | db2jcc4 |
| SQLite | sqlite-jdbc |
JDBC URLの形式
| DB | JDBC URL例 |
|---|---|
| MySQL | jdbc:mysql://localhost:3306/mydb?useSSL=false |
| PostgreSQL | jdbc:postgresql://localhost:5432/mydb |
| Oracle | jdbc:oracle:thin:@localhost:1521:ORCL |
| SQL Server | jdbc:sqlserver://localhost:1433;databaseName=mydb |
| SQLite | jdbc:sqlite:/path/to/db.sqlite |
最小のJDBC接続コード
|
import java.sql.*; |
主要なJDBCクラス
| クラス/インターフェース | 役割 |
|---|---|
DriverManager | 接続管理 |
Connection | 1つのDB接続 |
Statement | 静的SQL(非推奨。SQLi対策弱い) |
PreparedStatement | パラメータ化SQL(推奨) |
CallableStatement | ストアドプロシージャ呼び出し |
ResultSet | SELECT結果セット |
DataSource | 接続プール経由の取得(本番推奨) |
INSERT/UPDATE/DELETEの例
|
try (PreparedStatement ps = conn.prepareStatement( |
トランザクション
|
conn.setAutoCommit(false); |
本番運用の標準
- 接続プール: HikariCP、Apache DBCP、c3p0 等で接続を再利用
- DataSource:
DriverManagerではなくJNDI/Springから注入 - ORM: 直接JDBCを書くよりJPA / MyBatis / jOOQ等を使うことが多い
セキュリティの基本
- 必ず PreparedStatementを使う。SQLインジェクション対策
- パスワードをコードにハードコードしない(
.env/ Secrets Manager等) - DBユーザーは必要最小権限
- 本番ではSSL接続を強制(
useSSL=true&requireSSL=true等)
注意点
- リソースは必ずclose: try-with-resources を使うのが安全
- Statement vs PreparedStatement: 後者を常に使う(性能・セキュリティ両面で)
- 古い
Class.forName("com.mysql.jdbc.Driver")はJDBC 4.0以降不要
関連
- 親カテゴリ: 文法 (Java)
- SQL本体: SQL / SQL
- Java EE: Java EE
- Spring: Spring Framework
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子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
コメントを削除してもよろしいでしょうか?