Oracle 入门 ——SQL的简介与用法

oracle入门——sql简介与用法

看苏州首创科技(51Oracle.net) 提供您最优秀的选择!!
SQL语言简介  
  
1、 SQL概述  
SQL是一种面向数据库的通用数据处理语言规范,能完成以下几类功能:提取查询数据,插入修改删除数据,生成修改和删除数据库对象,数据库安全控制,数据库完整性及数据保护控制。  
数据库对象包括表、视图、索引、同义词、簇、触发器、函数、过程、包、数据库链、快照等(表空间、回滚段、角色、用户)。数据库通过对表的 *** 作来管理存储在其中的数据。  
  
1) SQL*PLUS界面:  
登录:输入SQLPLUS回车;输入正确的ORACLE用户名并回车;输入用户口令并回车,显示提示符:SQL>  
退出:输入EXIT即可。  
2)命令的编辑与运行:  
[$#61548] 在命令提示符后输入SQL命令并运行,以分号结束输入;以斜杠结束输入;以空行结束输入;  
[$#61548] 利用SQL缓冲区进行PL/SQL块的编辑和运行;  
[$#61548] 利用命令文件进行PL/SQL块的编辑和运行。  
  
2、 数据库查询  
1) 用SELECT语句从表中提取查询数据。语法为  
SELECT [DISTINCT] {column1,column2,…} FROM tablename WHERE {conditions} GROUP BY {conditions} ORDER BY {expressions} [ASC/DESC];   
说明:SELECT子句用于指定检索数据库的中哪些列,FROM子句用于指定从哪一个表或视图中检索数据。  
2) SELECT中的 *** 作符及多表查询WHERE子句。(LIKE,IS,…)  
   WHERE子句中的条件可以是一个包含等号或不等号的条件表达式,也可以是一个含有IN、NOT IN、BETWEEN、LIKE、IS NOT NULL等比较运算符的条件式,还可以是由单一的条件表达通过逻辑运算符组合成复合条件。  
3) ORDER BY   子句  
ORDER BY 子句使得SQL在显示查询结果时将各返回行按顺序排列,返回行的排列顺序由ORDER BY 子句指定的表达式的值确定。  
4) 连接查询  
利用SELECT语句进行数据库查询时,可以把多个表、视图的数据结合起来,使得查询结果的每一行中包含来自多个表达式或视图的数据,这种 *** 作被称为连接查询。  
连接查询的方法是在SELECT命令的FROM子句中指定两个或多个将被连接查询的表或视图,并且在WHERE子句告诉ORACLE如何把多个表的数据进行合并。根据WHERE子句中的条件表达式是等还是不等式,可以把连接查询分为等式连接和不等式连接。  
5) 子查询  
如果某一个SELECT命令(查询1)出现在另一个SQL命令(查询2)的一个子句中,则称查询1是查询2的子查询。  
  
3、 基本数据类型(NUMBER,VARCHAR2,DATE)  O  
  RACEL支持下列内部数据类型:  
[$#61548] VARCHAR2 变长字符串,最长为2000字符。  
[$#61548] NUMBER   数值型。  
[$#61548] LONG      变长字符数据,最长为2G字节。  
[$#61548] DATE       日期型。  
[$#61548] RAW       二进制数据,最长为255字节。  
[$#61548] LONG RAW  变长二进制数据,最长为2G字节。  
[$#61548] ROWID      二六进制串,表示表的行的唯一地址。  
[$#61548] CHAR       定长字符数据,最长为255。  
  
4、 常用函数用法:  
      一个函数类似于一个算符,它 *** 作数据项,返回一个结果。函数在格式上不同于算符,它个具有变元,可 *** 作0个、一个、二个或多个变元,形式为:  
函数名(变元,变元,…)  
函数具有下列一般类形:  
[$#61548] 单行函数  
[$#61548] 分组函数  
1) 单行函数对查询的表或视图的每一行返回一个结果行。它有数值函数,字符函数,日期函数,转换函数等。  
2) 分组函数返回的结果是基于行组而不是单行,所以分组函数不同于单行函数。在许多分组函数中可有下列选项:  
[$#61548] DISTRNCT 该选项使分组函数只考虑变元表达式中的不同值。  
[$#61548] ALL该选项使分组函数考虑全部值,包含全部重复。  
全部分组函数(除COUNT(*)外)忽略空值。如果具有分组函数的查询,没有返回行或只有空值(分组函数的变元取值的行),则分组函数返回空值。  
  
5、  数据 *** 纵语言命令:  
数据库 *** 纵语言(DML)命令用于查询和 *** 纵模式对象中的数据,它不隐式地提交当前事务。它包含UPDATE、INSERT、DELETE、EXPLAIN PLAN、SELECT和LOCK TABLE 等命令。下面简单介绍一下:  
1)  UPDATE tablename SET {column1=expression1,column2=expression2,…} WHERE {conditions};  
例如:S QL>UPDATE EMP   
       SET JOB =’MANAGER’  
       WHERE ENAME=’MAPTIN’;  
       SQL >SELECT * FROM EMP;  
UPDATE子句指明了要修改的数据库是EMP,并用WHERE子句限制了只对名字(ENAME)为’MARTIN’的职工的数据进行修改,SET子句则说明修改的方式,即把’MARTION’的工作名称(JOB)改为’MARAGER’.  
  
2) INSERT INTO tablename {column1,column2,…} VALUES {expression1,expression2,…};  
例如:SQL>SELECT INTO DEPT(DNAME, DEPTNO)  
       VALUES (‘ACCOUNTING’,10)  
  
3)   DELETE FROM tablename WHERE {conditions};  
例如:SQL>DELETE FROM EMP   
      WHERE EMPNO = 7654;  
DELETE命令删除一条记录,而且DELETE命令只能删除整行,而不能删除某行中的部分数据.  
  
4)  事务控制命令  
提交命令(COMMIT):可以使数据库的修改永久化.设置AUTOCOMMIT为允许状态:SQL >SET AUTOCOMMIT ON;  
回滚命令(ROLLBACK):消除上一个COMMIT命令后的所做的全部修改,使得数据库的内容恢复到上一个COMMIT执行后的状态.使用方法是:  
SQL>ROLLBACK;  
  
5、 创建表、视图、索引、同义词、用户。  
1) 、表是存储用户数据的基本结构。  
建立表主要指定义下列信息:  
[$#61548] 列定义  
[$#61548] 完整性约束  
[$#61548] 表所在表空间  
[$#61548] 存储特性  
[$#61548] 可选择的聚集  
[$#61548] 从一查询获得数据  
         语法如下:CREATE TABLE tablename   
(column1 datatype [DEFAULT expression] [constraint],  
  column1 datatype [DEFAULT expression] [constraint],  
  ……)  
[STORAGE子句]  
[其他子句…];  
例如:  
SQL>CREATE TABLE NEW_DEPT   
      (DPTNO NUMBER(2),  
      DNAME CHAR(6),  
LOC CHAR(13);  
更改表作用:  
[$#61548] 增加列  
[$#61548] 增加完整性约束  
[$#61548] 重新定义列(数据类型、长度、缺省值)  
[$#61548] 修改存储参数或其它参数  
[$#61548] 使能、使不能或删除一完整性约束或触发器  
[$#61548] 显式地分配一个范围  
2)、视图  
视图是一个逻辑表,它允许 *** 作者从其它表或视图存取数据,视图本身不包含数据。视图所基于的表称为基表。  
引入视图有下列作用:  
[$#61548] 提供附加的表安全级,限制存取基表的行或/和列集合。  
[$#61548] 隐藏数据复杂性。  
[$#61548] 为数据提供另一种观点。  
[$#61548] 促使ORACLE的某些 *** 作在包含视图的数据库上执行,而不在另一个数据库上执行。  
  
         3)、索引  
  索引是种数据库对象。对于在表或聚集的索引列上的每一值将包含一项,为行提供直接的快速存取。在下列情况ORACLE可利用索引改进性能:  
[$#61548] 按指定的索引列的值查找行。  
[$#61548] 按索引列的顺序存取表。  
        建立索引: CREATE [UNIQUE] INDEX indexname ON tablename(column ,。。。);  
例如:SQL>CREAT INDEX IC_EMP   
           ON CLUSTER EMPLOYEE  
  
4)、同义词  
同义词:为表、视图、序列、存储函数、包、快照或其它同义词的另一个名字。使用同义词为了安全和方便。对一对象建立同义词可有下列好处:  
[$#61548] 引用对象不需指出对象的持有者。  
[$#61548] 引用对象不需指出它所位于的数据库。  
[$#61548] 为对象提供另一个名字。  
建立同义词:  
CREATE SYNONYM symnon_name FOR [username.]tablename;  
例如:CREAT PUBLIC SYNONYM EMP   
       FOR SCOTT.EMP @SALES   
  
5)、用户  
CREATE USER username IDENTIFIED BY password;  
例如:SQL>CREATE USER SIDNEY   
            IDENTIFIED BY CARTON ;

作者: szsckj1   发布时间: 2011-07-05

入门不错!支持一下!

作者: penginpha   发布时间: 2011-07-05