Sql中的DDL和DML

对于数据分析人员,我们对数据库的操作无非就是建表、修改表结构、修改表内容(增删改)、查询表内容这些操作。下面总结了这些操作的区别

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

    • 不需要commit
    • 对表格的定义进行修改
    • 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)

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

    • 不需要commit
    • select 查询

猜你喜欢

转载自blog.csdn.net/lz_peter/article/details/85329223