この記事では、アプリケーションでのSQLのCOMMITとROLLBACKの実装方法について深掘りします。これらの処理はデータベースの一貫性を保つために非常に重要です。特に、複数の操作をトランザクションとしてまとめる場合には必須となります。
目次
COMMITとROLLBACKの基本
COMMITとは、データベースに対する一連の変更(トランザクション)を確定させる操作です。対照的に、ROLLBACKは確定前の状態にデータベースの変更を戻す操作です。
操作 | 説明 |
---|---|
COMMIT | データベースの変更を確定 |
ROLLBACK | 変更をキャンセルし、確定前の状態に戻す |
アプリケーションでのCOMMITとROLLBACKの実装
Pythonを使用した例
Pythonの場合、SQLiteやPostgreSQL、MySQLなどのデータベースライブラリを使用してCOMMITとROLLBACKを実装できます。
import sqlite3
try:
con = sqlite3.connect('example.db')
cur = con.cursor()
cur.execute("INSERT INTO table1 (name, age) VALUES ('John', 30)")
con.commit()
except Exception as e:
con.rollback()
print(e)
finally:
con.close()
Javaを使用した例
Javaの場合、JDBC(Java Database Connectivity)を使用してデータベース操作を行います。
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;
public class Main {
public static void main(String[] args) {
Connection con = null;
Statement stmt = null;
try {
con = DriverManager.getConnection("jdbc:mysql://localhost:3306/example", "user", "password");
con.setAutoCommit(false);
stmt = con.createStatement();
stmt.executeUpdate("INSERT INTO table1 (name, age) VALUES ('John', 30)");
con.commit();
} catch (Exception e) {
try {
con.rollback();
} catch (Exception ex) {
ex.printStackTrace();
}
e.printStackTrace();
} finally {
try {
stmt.close();
con.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
言語 | ライブラリ/フレームワーク | COMMITの方法 | ROLLBACKの方法 |
---|---|---|---|
Python | sqlite3 | con.commit() | con.rollback() |
Java | JDBC | con.commit() | con.rollback() |
まとめ
アプリケーションでのCOMMITとROLLBACKの実装は、データベースの一貫性を保つ上で非常に重要です。特に複数の操作を一つのトランザクションとして扱う場合には、これらの処理が必須となります。具体的な実装方法は使用する言語やライブラリに依存しますが、基本的な考え方は共通です。
created by Rinker
¥4,554
(2025/01/18 14:22:31時点 Amazon調べ-詳細)
コメント