找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索本站精品资源

首页 教程频道 mysql教程 查看内容

create需要commit么

作者:模板之家 2019-5-20 16:58 553人关注

首先你需要了解数据库的sql语言:数据定义语言DDL,数据操纵语言DML,数据查询语言DQL,数据控制语言DCL,如果create属于DDL,不需要写commit,因为内部已经隐藏了,反之就需要。

想知道create是否需要commit,你需要了解这些基本的数据库sql语言的知识。

DDL:数据库定义语言,用来创建数据库,创建表格等。

DML:数据库管理语言,如增删改查语句等 。

DCL:数据库操作语言,如修改数据库系统权限。

DQL:数据查询语言,如模糊查询,连接查询。

这里就DML,DDL进行一个对比。

DML语言,比如update,delete,insert等修改表中数据的需要commit;
DDL语言,比如create,drop等改变表结构的,就不需要写commit(因为内部隐藏了commit);

DDL 数据定义语言:
create table 创建表
alter table 修改表
drop table 删除表
truncate table 删除表中所有行
create index 创建索引
drop index 删除索引
当执行DDL语句时,在每一条语句前后,oracle都将提交当前的事务。如果用户使用insert命令将记录插入到数据库后,执行了一条DDL语句(如create table),此时来自insert命令的数据将被提交到数据库。当DDL语句执行完成时,DDL语句会被自动提交,不能回滚。

DML 数据操作语言:
insert 将记录插入到数据库
update 修改数据库的记录
delete 删除数据库的记录
当执行DML命令如果没有提交,将不会被其他会话看到。除非在DML命令之后执行了DDL命令或DCL命令,或用户退出会话,或终止实例,此时系统会自动
发出commit命令,使未提交的DML命令提交。

以上就是create需要commit么的详细内容,更多请关注模板之家(www.mb5.com.cn)其它相关文章!


路过

雷人

握手

鲜花

鸡蛋
来自: [db:来源]

全部回复(0)

发表评论