首发微信公众号:SQL数据库运维
通过之前文章的更新讲解,大家现在应该已经对SQL有个大概的认识了,如果还是有些许不了解的话,可以温习下之前的文章,温故而知新:SQL 语法、SQL 简介(点击文字可跳转至链接文章)这两篇文章,此篇文章主要是针对Oracle数据库而言。
SQL是一个结构化的的查询语言(Structured Query Language ),众所周知,在日常开发、运维中使用SQL语句可以对Oracle进行对象的创建、删除,数据的插入、删除、更新,以及数据库的管理等操作,但是SQL不仅仅适用于Oracle数据库,在MySQL、SQL Server、PostgreSQL等其它的数据库同样也适用,如果非要说有哪些不同点的话,最多也就是部分函数的写法及使用方法不同。
在 Oracle 开发中,客户端把 SQL 语句发送给服务器,服务器对 SQL 语句进行编译、执行,最后,把执行的结果返回给客户端。在这个过程中,常用的SQL语句大致可以分为五类:
-
数据定义语言(DDL):是用于描述数据库中要存储的现实世界实体的语言。包括 CREATE(创建table或者view)命令、 ALTER(修改)命令、 DROP(删除)、TRUNCATE(只删除 数据不删除表的结构)命令等。
-
数据操作语言(DML):主要功能即是访问数据,因此其语法都是以读取与写入数据库为主。包括 INSERT(插入)命令、 UPDATE(更新)命令、 DELETE(删除)命令等。
-
数据查询语言(DQL):查询是SQL语言的核心,SQL语言只提供唯一一个用于数据库查询的语句,即SELECT语句。包括基本查询SELECT语句、 Order By 子句、 Group By 子句等。DQL是数据开发工作者最经常使用的语言,掌握DQL是重中之重。
-
事务控制语言(TCL):事务是由一系列对数据库表中数据进行访问和更新的操作所组成的一个执行逻辑单元。只有DML语句才会产生事务,其他语句不会产生事务。包括 COMMIT(提交)命令、 SAVEPOINT(保存点)命令、ROLLBACK(回滚)命令。
-
数据控制语言(DCL):是一种可对数据访问权进行控制的指令,它可以控制特定用户账户对数据表、查看表、存储程序、用户自定义函数等数据库对象的控制权。包括GRANT(授权用户权限)命令、 REVOKE(撤销用户权限)命令。在默认状态下,操作需在sys或在system用户下完成,使用sysdba或sysoper角色才有权力执行DCL。