- Mastering PostgreSQL 9.6
- Hans Jurgen Schonig
- 281字
- 2021-07-09 19:57:12
Transactional DDLs
PostgreSQL has a very nice feature that is unfortunately not present in many commercial database systems. In PostgreSQL, it is possible to run DDLs (commands that change the data structure) inside a transaction block. In a typical commercial system, a DDL will implicitly commit the current transaction. Not so in PostgreSQL.
Apart from some minor exceptions (DROP DATABASE, CREATE TABLESPACE/DROP TABLESPACE, and so on), all DDLs in PostgreSQL are transactional, which is a huge plus and a real benefit to end users.
Here is an example:
test=# d
No relations found.
test=# BEGIN;
BEGIN
test=# CREATE TABLE t_test (id int);
CREATE TABLE
test=# ALTER TABLE t_test ALTER COLUMN id TYPE int8;
ALTER TABLE
test=# d t_test
Table "public.t_test"
Column | Type | Modifiers
--------+--------+-----------
id | bigint |
test=# ROLLBACK;
ROLLBACK
test=# d t_test
Did not find any relation named "t_test".
In this example, a table has been created and modified, and the entire transaction is aborted instantly. As you can see, there is no implicit COMMIT or any other strange behavior. PostgreSQL simply acts as expected.
Transactional DDLs are especially important if you want to deploy software. Just imagine running a CMS. If a new version is released, you'll want to upgrade. Running the old version would still be OK; running the new version is also OK but you really don't want a mixture of old and new. Therefore, deploying an upgrade in a single transaction is definitely highly beneficial as it makes upgrades an atomic operation.
- 電氣自動化專業英語(第3版)
- Deep Learning Quick Reference
- Hadoop 2.x Administration Cookbook
- JMAG電機電磁仿真分析與實例解析
- 計算機網絡應用基礎
- 現代機械運動控制技術
- 基于多目標決策的數據挖掘方法評估與應用
- INSTANT Autodesk Revit 2013 Customization with .NET How-to
- Splunk Operational Intelligence Cookbook
- 基于單片機的嵌入式工程開發詳解
- 走近大數據
- INSTANT Munin Plugin Starter
- Mastering Geospatial Analysis with Python
- Mastering Ceph
- JRuby語言實戰技術