DML、DDL、DCL区别

来源:未知 责任编辑:责任编辑 发表时间:2013-11-18 20:57 点击:

 

总体解释:

DML(data manipulation language):

       它们是SELECT、UPDATE、INSERT、DELETE,就象它的名字一样,这4条命令是用来对数据库里的数据进行操作的语言

DDL(data definition language):

       DDL比DML要多,主要的命令有CREATE、ALTER、DROP等,DDL主要是用在定义或改变表(TABLE)的结构,数据类型,表之间的链接和约束等初始化工作上,他们大多在建立表时使用

DCL(Data Control Language):

       是数据库控制功能。是用来设置或更改数据库用户或角色权限的语句,包括(grant,deny,revoke等)语句。在默认状态下,只有sysadmin,dbcreator,db_owner或db_securityadmin等人员才有权力执行DCL

详细解释:

一、DDL is Data Definition Language statements. Some examples:数据定义语言,用于定义和管理SQL 数据库中的所有对象的语言

      1.CREATE - to create objects in the database   创建

      2.ALTER - alters the structure of the database   修改

      3.DROP - delete objects from the database   删除

      4.TRUNCATE - remove all records from a table, including all spaces allocated for the records are removed

      TRUNCATE TABLE [Table Name]。

  下面是对Truncate语句在MSSQLServer2000中用法和原理的说明:

  Truncate table 表名 速度快,而且效率高,因为:

  TRUNCATE TABLE 在功能上与不带WHERE 子句的DELETE 语句相同:二者均删除表中的全部行。但TRUNCATE TABLE 比DELETE 速度快,且使用的系统和事务日志资源少。

  DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项。TRUNCATE TABLE 通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放。

  TRUNCATE TABLE 删除表中的所有行,但表结构及其列、约束、索引等保持不变。新行标识所用的计数值重置为该列的种子。如果想保留标识计数值,请改用DELETE。如果要删除表定义及其数据,请使用DROP TABLE 语句。

  对于由FOREIGN KEY 约束引用的表,不能使用TRUNCATE TABLE,而应使用不带WHERE 子句的DELETE 语句。由于TRUNCATE TABLE 不记录在日志中,所以它不能激活触发器。

  TRUNCATE TABLE 不能用于参与了索引视图的表。

       5.COMMENT - add comments to the data dictionary 注释

       6.GRANT - gives user's access privileges to database 授权

       7.REVOKE - withdraw access privileges given with the GRANT command   收回已经授予的权限

二、DML is Data Manipulation Language statements. Some examples:数据操作语言,SQL中处理数据等操作统称为数据操纵语言

       1.SELECT - retrieve data from the a database           查询

       2.INSERT - insert data into a table                    添加

发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
用户名: 验证码:点击我更换图片
最新评论 更多>>

推荐热点

  • Table函数使用简介
  • Oracle数据库Constraint约束的常用操作及异常处理
  • Bulk Collect性能分析(zz)
  • export/import的使用
  • OCP043第十五讲 Database Security
  • ORACLE10gr2数据导入MySQL方案
  • oracle 让sys用户可以使用isqlplus
  • 在oracle数据库下使用iSQL*Plus DBA访问数据库
  • Oracle行列转换小结
网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
Copyright © 2008-2015 计算机技术学习交流网. 版权所有

豫ICP备11007008号-1