中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 数据库开发 > 数据库综合
Oracle培训教材
作者:未知 时间:2004-11-05 12:12 出处:Blog 责编:chinaitpower
              摘要:暂无

 

一.SQL语言简介

1. SQL概述

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子句中的条件可以是一个包含等号或不等号的条件表达式,也可以是一个含有INNOT INBETWEENLIKEIS NOT NULL等比较运算符的条件式,还可以是由单一的条件表达通过逻辑运算符组合成复合条件。

比较操作符 =  >  <  >=  <=  !=  <>

SQL操作符 BETWEEN AND          IN   LIKE            IS NULL     

              NOT BETWEEN … AND… NOT IN NOT LIKE   IS NOT NULL

逻辑操作符 AND      OR  NOT

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 

 ORACEL支持下列内部数据类型:

l       VARCHAR2 变长字符串,最长为2000字符。

l       NUMBER   数值型。

l       LONG      变长字符数据,最长为2G字节。

l       DATE       日期型。

l       RAW       二进制数据,最长为255字节。

l       LONG RAW  变长二进制数据,最长为2G字节。

l       ROWID      二六进制串,表示表的行的唯一地址。

l       CHAR       定长字符数据,最长为255

 

4.     常用函数用法:

     一个函数类似于一个算符,它操作数据项,返回一个结果。函数在格式上不同于算符,它个具有变元,可操作0个、一个、二个或多个变元,形式为:

函数名(变元,变元,…)

函数具有下列一般类形:

l         单行函数

l         分组函数

1)单行函数对查询的表或视图的每一行返回一个结果行。它有数值函数,字符函数,日期函数,转换函数等。

2)分组函数返回的结果是基于行组而不是单行,所以分组函数不同于单行函数。在许多分组函数中可有下列选项:

l         DISTRNCT 该选项使分组函数只考虑变元表达式中的不同值。

l         ALL该选项使分组函数考虑全部值,包含全部重复。

全部分组函数(除COUNT*)外)忽略空值。如果具有分组函数的查询,没有返回行或只有空值(分组函数的变元取值的行),则分组函数返回空值。

l       单行函数

1)        数字函数

ABS  取绝对值  POWER 乘方   LN   10为底数取冪

SQRT 平方根     EXP       en次乘方  LOG(m,n)   m为底数n取冪        

数学运算函数:ACOS ATAN ATAN2 COS COSH  SIGN SIN SINH TAN TANH

CEIL   大于或等于取整数  

FLOOR        小于或等于取整数

MOD          取余数               

ROUND(n,m)   m的位数取四舍五入值如果round(日期): 中午12以后将是明天的日期. round(sysdate,'Y')是年的第一天

TRUNC(n,m) m的位数取前面的数值如果trunc(日期), 确省的是去掉时间

 

2)        字符函数

CHR                   按数据库的字符集由数字返回字符 

CONCAT(c1,c2)              把两个字符c1,c2组合成一个字符, || 相同

REPLACE(c,s,r)        把字符c里出现s的字符替换成r, 返回新字符

SUBSTR(c,m,n)           m大于0,字符c从前面m处开始取n位字符,m等于01一样,

               m小与0,字符c从后面m处开始取n位字符

TRANSLATE(c,f1,t1)       字符cf1t1的规则转换成新的字符串

INITCAP             字符首字母大写,其它字符小写

LOWER                     字符全部小写

UPPER                 字符全部大写

LTRIM(c1,c2)              去掉字符c1左边出现的字符c2

RTRIM(c1,c2)

TRIM(c1,c2)               去掉字符c1左右两边的字符c2

LPAD(c1,n,c2)            字符c1按制定的位数n显示不足的位数用c2字符串替换左边的空位

RPAD(c1,n,c2)

 

3)        日期函数

ADD_MONTHS(d,n)                日期值加n

LAST_DAY(d)                  返回当月的最后一天的日期

MONTHS_BETWEEN(d1,d2)               两个日期值间的月份,d1<d2 返回负数

NEXT_DAY(d)                 返回日期值下一天的日期

SYSDATE                  当前的系统时间

                      DUALSYS用户下一个空表,它只有一个字段dummy

4)        转换函数(1)

TO_CHAR(date,'日期显示格式')         

TO_CHAR(number)                 用于显示或报表的格式对齐

TO_DATE(char,'日期显示格式')          

TO_LOB                                 long字段转换成lob字段

TO_NUMBER(char)                        用于计算或者比较大小

 

5)        转换函数(2)

to_date里日期显示格式

YYYY             YEAR    YYY      YY  Y

Q           季度     

MM                 MONTH       MON    

W          星期 (week of month)       WW, IW (week of year)   

(说明:周计是按ISO标准,11日的星期数到后面七天为一周,不一定是从周一到周日)

DD            DAY             DY 

HH24            小时      HH12            HH 

MI         分钟     

SS         

如果想固定日期的显示格式可以在数据库的参数文件initorasid.ora里新写一行参数 NLS_DATE_FORMAT=yyyy-mm-dd hh24:mi:ss可以在UNIX环境变量或者NT的注册表里的设置 NLS_DATE_FORMAT=yyyy-mm-dd hh24:mi:ss

 

6)        转换函数(3)

如果想固定日期的显示格式可以用alter session命令改变

SQL> alter session set nls_date_format='yyyy-mm-dd hh24:mi:ss';

它的作用顺序如下:

initialization parameter

Environment variable

ALTER SESSION command

 

7)        转换函数 (4)

to_char(number)里数字显示格式

9     数字位

0     数字前面补0                  to_char(-1200,'00000.00')

.      小数点的位置   

,      标记位置的逗号       用在数字显示格式的左边           

L     根据数据库字符集加货币符号    to_char(-1200,'L9999.99')       

B     把数字0显示为空格,用在数字显示格式的右边

       

MI  右边的负数标记                       to_char(-1200,'9999.99MI')

PR    括起来的负数                     to_char(-1200,'9999.99PR')

EEEE     用指数方式表示                        to_char(-1200,'9999.99EEEE')

 

8)        输入字符,返回数字的函数

instr(c1,c2)     字符c2出现在c1的位置, 不出现, 返回0, 常用于模糊查询

length(c)  按数据库的字符集,算出字符c的长度,跟数据库的字符集有关, 一个汉字长度为1

 

9)        有逻辑比较的函数NVL(EXPR1, EXPR2)函数

解释:      IF EXPR1=NULL      RETURN EXPR2

        ELSE    RETURN EXPR1

10)    DECODE(AAV1R1V2R2....)函数

解释: IF AA=V1 THEN RETURN R1

          IF AA=V2 THEN RETURN R2

        ..…

  ELSE

  RETURN NULL           

举例: decode(id,1,'dept sale',2,'dept tech')

l        集合函数      经常和group by一起使用

1)      集合函数列表

AVG             (DISTINCT | ALL | N)                     取平均值

COUNT        (DISTINCT | ALL | N | expr | * )     统计数量

MAX             (DISTINCT | ALL | N)                     取最大值

MIN             (DISTINCT | ALL | N)                     取最小值

SUM             (DISTINCT | ALL | N)                     取合计值

STDDEV             (DISTINCT | ALL | N)                     取偏差值,如果组里选择的内容都相同,结果为0

VARIANCE (DISTINCT | ALL | N)                        取平方偏差值

 

2)      使用集合函数的语法

SELECT column, group_function FROM table

WHERE condition       GROUP BY group_by_expression

HAVING group_condition  ORDER BY column;

3)      使用count时的注意事项

SELECT COUNT(*) FROM table;

SELECT COUNT(常量) FROM table;

 

都是统计表中记录数量,如果没有PK后者要好一些

SELECT COUNT(all 字段名) FROM table;

SELECT COUNT(字段名) FROM table;

 

不会统计为NULL的字段的数量

SUM,AVG时都会忽略为NULL的字段

 

4)    group by时的限制条件

SELECT字段名不能随意, 要包含在GROUP BY的字段里

 GROUP BYORDER BY时不能用位置符号和别名

 限制GROUP BY的显示结果, HAVING条件

 

5)      例子

SQL> select title,sum(salary) payroll from s_emp

where title like 'VP%'   group by title

having sum(salary)>5000    order by sum(salary) desc;

找出某表里字段重复的记录数, 并显示

SQL> select (duplicate field names) from table_name

     group by (list out fields) having count(*)>1;

5. 数据操纵语言命令:

数据库操纵语言(DML)命令用于查询和操纵模式对象中的数据,它不隐式地提交当前事务。它包含UPDATEINSERTDELETEEXPLAIN PLANSELECTLOCK 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 DEPTDNAME DEPTNO

                     VALUES (‘ACCOUNTING’,10