mysql dml回滚_数据库回滚与DDL、DML

本文介绍了DDL(如创建、修改、删除表等)和DML(如插入、更新、删除记录)在数据库操作中的事务处理。DDL执行时会自动提交事务,无法回滚,而DML在没有提交的情况下不会被其他会话看到。同时,文章列出了不同数据库操作(如添加、删除索引,更改主键等)的在线DDL支持情况,详细阐述了各种操作是否就地进行、重建表、允许并发DML及仅修改元数据的情况。
摘要由CSDN通过智能技术生成

DDL (Data Definition Language 数据定义语言)

create table 创建表

alter table 修改表

drop table 删除表

truncate table 删除表中所有行

create index 创建索引

drop index 删除索引

当执行DDL语句时,在每一条语句前后,oracle都将提交当前的事务。如果用户使用insert命令将记录插入到数据库后,执行了一条DDL语句(如create table),此时来自insert命令的数据将被提交到数据库。当DDL语句执行完成时,DDL语句会被自动提交,不能回滚。

DML (Data Manipulation Language 数据操作语言)

insert 将记录插入到数据库

update 修改数据库的记录

delete 删除数据库的记录

当执行DML命令如果没有提交,将不会被其他会话看到。除非在DML命令之后执行了DDL命令或DCL命令,或用户退出会话,或终止实例,此时系统会自动发出commit命令,使未提交的DML命令提交。

Table 14.8 Online DDL Support for Index Operations

OperationIn PlaceRebuilds TablePermits Concurrent DMLOnly Modifies Metadata

Creating or adding a secondary index

Yes

No

Yes

No

Dropping an index

Yes

No

Yes

Yes

Adding aFULLTEXTindex

Yes*

No*

No

No

Table 14.9 Online DDL Support for Primary Key Operations

OperationIn PlaceRebuilds TablePermits Concurrent DMLOnly Modifies Metadata

Adding a primary key

Yes*

Yes*

Yes

No

Dropping a primary key

No

Yes

No

No

Dropping a primary key and adding another

Yes

Yes

Yes

No

Table 14.10 Online DDL Support for Column Operations

OperationIn PlaceRebuilds TablePermits Concurrent DMLOnly Modifies Metadata

Adding a column

Yes

Yes

Yes*

No

Dropping a column

Yes

Yes

Yes

No

Renaming a column

Yes

No

Yes*

Yes

Reordering columns

Yes

Yes

Yes

No

Setting a column default value

Yes

No

Yes

Yes

Changing the column data type

No

Yes

No

No

Dropping the column default value

Yes

No

Yes

Yes

Changing the auto-increment value

Yes

No

Yes

No*

Making a columnNULL

Yes

Yes*

Yes

No

Making a columnNOT NULL

Yes*

Yes*

Yes

No

Table 14.11 Online DDL Support for Foreign Key Operations

OperationIn PlaceRebuilds TablePermits Concurrent DMLOnly Modifies Metadata

Adding a foreign key constraint

Yes*

No

Yes

Yes

Dropping a foreign key constraint

Yes

No

Yes

Yes

Table 14.12 Online DDL Support for Table Operations

OperationIn PlaceRebuilds TablePermits Concurrent DMLOnly Modifies Metadata

Changing theROW_FORMAT

Yes

Yes

Yes

No

Changing theKEY_BLOCK_SIZE

Yes

Yes

Yes

No

Setting persistent table statistics

Yes

No

Yes

Yes

Specifying a character set

Yes*

Yes*

No

No

Converting a character set

No

Yes

No

No

Optimizing a table

Yes*

Yes

Yes

No

Rebuilding with theFORCEoption

Yes*

Yes

Yes

No

Performing a null rebuild

Yes*

Yes

Yes

No

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值