SQL语言简介

 

 
一、SQL概述
 
   SQL是一种面向数据库的通用数据处理语言规范,能完成如下几类功能:
提取查询数据,插入修改删除数据,生成修改和删除数据库对象,数据库安全控制,
数据库完整性及数据保护控制。
 
数据库对象包括:
    表、视图、索引、同义词、簇、触发器、函数、过程、包、数据库链、快照等
(表空间、回滚段、角色、用户)。数据库经过对表的操做来管理存储在其中的数据。
 
1)SQL*PLUS界面:
登陆:输入SQLPLUS回车;
      输入正确的ORACLE用户名并回车;
      输入用户口令并回车,显示提示符:SQL>
退出:输入EXIT便可。
 
2)命令的编辑与运行:
    在命令提示符后输入SQL命令并运行,以分号结束输入;以斜杠结束输入;以空行结束输入;
    利用SQL缓冲区进行PL/SQL块的编辑和运行;
    利用命令文件进行PL/SQL块的编辑和运行。
 
二、数据库查询 
   用SELECT语句从表中提取查询数据。
语法为:
SELECT [DISTINCT] {column1,column2,…} 
FROM tablename 
WHERE {conditions} 
GROUP BY {conditions} 
ORDER BY {expressions} [ASC/DESC];
 
 
说明:
一、SELECT子句用于指定检索数据库的中哪些列,FROM子句用于指定从哪个表或视图中检索数据。
 
二、SELECT中的操做符及多表查询WHERE子句。(LIKE,IS,…)
  WHERE子句中的条件能够是一个包含等号或不等号的条件表达式,也能够是一个含有IN、NOT IN、BETWEEN、LIKE、IS NOT NULL等比较运算符的条件式,还能够是由单一的条件表达经过逻辑运算符组合成复合条件。
 
三、ORDER BY 子句
ORDER BY 子句使得SQL在显示查询结果时将各返回行按顺序排列,返回行的排列顺序由ORDER BY子句指定的表达式的值肯定。
 
四、链接查询
利用SELECT语句进行数据库查询时,能够把多个表、视图的数据结合起来,使得查询结果的每一行中包含来自多个表达式或视图的数据,这种操做被称为链接查询。
链接查询的方法是在SELECT命令的FROM子句中指定两个或多个将被链接查询的表或视图,而且在WHERE子句告诉ORACLE如何把多个表的数据进行合并。根据WHERE子句中的条件表达式是等仍是不等式,能够把链接查询分为等式链接和不等式链接。
 
五、子查询
若是某一个SELECT命令(查询1)出如今另外一个SQL命令(查询2)的一个子句中,则称查询1是查询2的子查询。
 
三、基本数据类型(NUMBER,VARCHAR2,DATE)  
 ORACEL支持下列内部数据类型:
VARCHAR2 变长字符串,最长为2000字符。
NUMBER   数值型。
LONG     变长字符数据,最长为2G字节。
DATE     日期型。
RAW      二进制数据,最长为255字节。
LONG RAW 变长二进制数据,最长为2G字节。
ROWID    二六进制串,表示表的行的惟一地址。
CHAR     定长字符数据,最长为255。
BLOB     大的二进制数据,最大2G
CLOB     大的文本数据,最大2G
NBLOB    超大的二进制数据,最大4G
NCLOB    超大的文本字符数据,最大4G
 
 
四、经常使用函数用法:
     一个函数相似于一个算符,它操做数据项,返回一个结果。函数在格式上不一样于算符,
它个具备变元,可操做0个、一个、二个或多个变元,形式为:
函数名(变元,变元,…)
函数具备下列通常类形:
单行函数:对查询的表或视图的每一行返回一个结果行。它有数值函数,字符函数,日期函数,转换函数等。
分组函数:返回的结果是基于行组而不是单行,因此分组函数不一样于单行函数。在许多分组函数中可有下列选项:
DISTRNCT 该选项使分组函数只考虑变元表达式中的不一样值。
ALL该选项使分组函数考虑所有值,包含所有重复。
所有分组函数(除COUNT(*)外)忽略空值。若是具备分组函数的查询,没有返回行或只有空值(分组函数的变元取值的行),则分组函数返回空值。
 
 
五、数据操纵语言命令:
数据库操纵语言(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;
 
六、建立表、视图、索引、同义词、用户。
七、表是存储用户数据的基本结构。
创建表主要指定义下列信息:
列定义
完整性约束
表所在表空间
存储特性
可选择的汇集
从一查询得到数据
        语法以下: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);
更改表做用:
增长列
增长完整性约束
从新定义列(数据类型、长度、缺省值)
修改存储参数或其它参数
使能、使不能或删除一完整性约束或触发器
显式地分配一个范围
2)、视图
视图是一个逻辑表,它容许操做者从其它表或视图存取数据,视图自己不包含数据。视图所基于的表称为基表。
引入视图有下列做用:
提供附加的表安全级,限制存取基表的行或/和列集合。
隐藏数据复杂性。
为数据提供另外一种观点。
促使ORACLE的某些操做在包含视图的数据库上执行,而不在另外一个数据库上执行。
 
 
3)、索引
索引是种数据库对象。对于在表或汇集的索引列上的每一值将包含一项,为行提供直接的快速存取。在下列状况ORACLE可利用索引改进性能:
按指定的索引列的值查找行。
按索引列的顺序存取表。
        创建索引: CREATE [UNIQUE] INDEX indexname ON tablename(column ,。。。);
例如:SQL>CREAT INDEX IC_EMP 
          ON CLUSTER EMPLOYEE
 
4)、同义词
同义词:为表、视图、序列、存储函数、包、快照或其它同义词的另外一个名字。使用同义词为了安全和方便。对一对象创建同义词可有下列好处:
引用对象不需指出对象的持有者。
引用对象不需指出它所位于的数据库。
为对象提供另外一个名字。
创建同义词:
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 ;
相关文章
相关标签/搜索