Oracle SQL语言
更新时间:2024-03-20 03:06:01 阅读量: 综合文库 文档下载
- oracle数据库推荐度:
- 相关推荐
Oracle SQL语言
http://www.chinaunix.net 作者:jimijiao 发表于:2003-09-17 14:17:11
数据库对象包括表、视图、索引、同义词、簇、触发器、函数、过程、包、数据库链、快照等(表空间、回滚段、角色、用户)。数据库通过对表的操作来管理存储在其中的数据。
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) O RACEL支持下列内部数据类型:
VARCHAR2 变长字符串,最长为2000字符。 NUMBER 数值型。
LONG 变长字符数据,最长为2G字节。 DATE 日期型。 RAW 二进制数据,最长为255字节。 LONG RAW 变长二进制数据,最长为2G字节。 ROWID 二六进制串,表示表的行的唯一地址。
CHAR 定长字符数据,最长为255。
常用函数用法:
一个函数类似于一个算符,它操作数据项,返回一个结果。函数在格式上不同于算符,它个具有变元,可操作0个、一个、二个或多个变元,形式为: 函数名(变元,变元,…) 函数具有下列一般类形: 单行函数
分组函数
单行函数对查询的表或视图的每一行返回一个结果行。它有数值函数,字符函数,日期函数,转换函数等。 分组函数返回的结果是基于行组而不是单行,所以分组函数不同于单行函数。在许多分组函数中可有下列选项:
DISTRNCT 该选项使分组函数只考虑变元表达式中的不同值。
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;
创建表、视图、索引、同义词、用户。 、表是存储用户数据的基本结构。 建立表主要指定义下列信息: 列定义 完整性约束 表所在表空间 存储特性
可选择的聚集
从一查询获得数据 语法如下: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 ; Oracle扩展PL/SQL简介
PL/SQL概述。
PL/SQL是Oracle对SQL规范的扩展,是一种块结构语言,即构成一个PL/SQL程序的基本单位(过程、函数和无名块)是逻辑块,可包含任何数目的嵌套了快。这种程序结构支持逐步求精方法解决问题。一个块(或子块)将逻辑上相关的说明和语句组合在一起,其形式为: DECLARE ---说明 BEGIN ---语句序列 EXCEPTION ---例外处理程序 END;
它有以下优点: 支持SQL; 生产率高; 性能好; 可称植性;
与ORACLE集成.
PL/SQL体系结构
PL/SQL运行系统是种技术,不是一种独立产品,可认为这种技术是PL/SQL块和子程序的一种机,它可接收任何有效的PL/SQL块或子程序。如图所示:
PL/SQL机可执行过程性语句,而将SQL语句发送到ORACLE服务器上的SQL语句执行器。在ORACLE预编译程序或O
CI程序中可嵌入无名的PL/SQL块。如果ORACLE具有PROCEDURAL选件,有名的PL/SQL块(子程序)可单独编译,永久地存储在数据库中,准备执行。
PL/SQL基础:
PL/SQL有一字符集、保留字、标点、数据类型、严密语法等,它与SQL有相同表示,现重点介绍。 1)、数据类型:如下表所示 数据类型 子类型
纯量类型 数值 BINARY_INTEGER NATURAL,POSITIVE NUMBER DEC,DECIMAL,DOUBLE PRECISION,PLOAT,INTEGER,INT,NUMERIC,REAL,SMALLINT 字符 CHAR CHARACTER,STRING VARCHAR2 VARCHAR LONG
LONG RAW RAW RAWID
逻辑 BOOLEAN 日期 DATE
组合 类型 记录 RECORD 表 TABLE 2)、变量和常量
在PL/SQL程序中可将值存储在变量和常量中,当程序执行时,变量的值可以改变,而常量的值不能改变。 3)、程序块式结构: DECLARE
变量说明部分; BEGIN
执行语句部分; [EXCEPTION 例外处理部分;] END;
控制语句: 分支语句: IF condition THEN Sequence_of_statements; END IF;
IF condition THEN
Sequence_of_statement1; ELSE
Sequence_of_statement2; END IF;
IF condition1 THEN Sequence_of_statement1; ELSIF condition2 THEN Sequence_of_statement2; ELSIF condition3 THEN Sequence_of_statement3; END IF;
循环语句: LOOP
Sequence_of_statements; IF condition THEN EXIT; END IF; END LOOP;
WHILE condition LOOP Sequence_of_statements; END LOOP;
FOR counter IN lower_bound..higher_bound LOOP Sequence_of_statements; END LOOP;
子程序:
存储过程:
CREATE PROCEDURE 过程名 (参数说明1,参数说明2, 。。。) IS [局部说明] BEGIN 执行语句; END 过程名;
存储函数:
CREATE FUNCTION 函数名 (参数说明1,参数说明2, 。。。)
RETURN 类型 IS [局部说明] BEGIN
执行语句; END 函数名;
truncate,delete,drop的异同点
http://www.chinaunix.net 作者:oraix 发表于:2004-02-04 10:49:25
注意:这里说的delete是指不带where子句的delete语句 相同点
truncate和不带where子句的delete, 以及drop都会删除表内的数据
不同点:
1. truncate和 delete只删除数据不删除表的结构(定义)
drop语句将删除表的结构被依赖的约束(constrain),触发器(trigger),索引(index); 依赖于该表的存储过程/函数将保留,但是变为invalid状态.
2.delete语句是dml,这个操作会放到rollback segement中,事务提交之后才生效;如果有相应的trigger,执行的时候将被触发. truncate,drop是ddl, 操作立即生效,原数据不放到rollback segment中,不能回滚. 操作不触发trigger.
3.delete语句不影响表所占用的extent, 高水线(high watermark)保持原位置不动
显然drop语句将表所占用的空间全部释放
truncate 语句缺省情况下见空间释放到 minextents个 extent,除非使用reuse storage; truncate会将高水线复位(回到最开始). 4.速度,一般来说: drop> truncate > delete
5.安全性:小心使用drop 和truncate,尤其没有备份的时候.否则哭都来不及
使用上,想删除部分数据行用delete,注意带上where子句. 回滚段要足够大.
想删除表,当然用drop
想保留表而将所有数据删除. 如果和事务无关,用truncate即可. 如果和事务有关,或者想触发trigger,还是用delete. 如果是整理表内部的碎片,可以用truncate跟上reuse stroage,再重新导入/插入数据
个人总结,欢迎大家补充
【发表回复】【查看论坛原帖】【添加到收藏夹】【关闭】
SQL*PLUS常用命令列表
http://www.chinaunix.net 作者:horse 发表于:2003-12-17 18:51:24
[color=blue:557795a379][size=18:557795a379]命令列表[/size:557795a379][/color:557795a379]:
假设当前执行命令为:select * from tab;
(a)ppend 添加文本到缓冲区当前行尾 a order by tname 结果:select * from tab order by tname; (注:a后面跟2个空格) (c)hange/old/new 在当前行用新的文本替换旧的文本 c/*/tname 结果:select tname from tab;
(c)hange/text 从当前行删除文本 c/tab 结果:select tname from ; del 删除当前行 del n 删除第n行
(i)nput 文本 在当前行之后添加一行 (l)ist 显示缓冲区中所有行 (l)ist n 显示缓冲区中第 n 行 (l)ist m n 显示缓冲区中 m 到 n 行 run 执行当前缓冲区的命令 / 执行当前缓冲区的命令 r 执行当前缓冲区的命令
@文件名 运行调入内存的sql文件,如:
SQL> edit s<回车>
如果当前目录下不存在s.sql文件,则系统自动生成s.sql文件,
在其中输入“select * from tab;”,存盘退出。
SQL> @s<回车>
系统会自动查询当前用户下的所有表、视图、同义词。
@@文件名 在.sql文件中调用令一个.sql文件时使用
save 文件名 将缓冲区的命令以文件方式存盘,缺省文件扩展名为.sql
get 文件名 调入存盘的sql文件 start 文件名 运行调入内存的sql文件
spool 文件名 把这之后的各种操作及执行结果“假脱机”即存盘到磁盘文件上,默认文件扩展名为.lst
spool 显示当前的“假脱机”状态 spool off 停止输出
例: SQL> spool a SQL> spool
正假脱机到 A.LST SQL> spool off SQL> spool 当前无假脱机
exit 退出SQL*PLUS desc 表名 显示表的结构 show user 显示当前连接用户 show error 显示错误
show all 显示所有68个系统变量值
edit 打开默认编辑器,Windows系统中默认是notepad.exe,把缓冲区中最后一条SQL语句调入afiedt.buf文件中进行编辑
edit 文件名 把当前目录中指定的.sql文件调入编辑器进行编辑
clear screen 清空当前屏幕显示
更改数据库用户密码可通过在 sqlplus 执行 alter user identified by 密码 的命令而实现
【发表回复】【查看论坛原帖】【添加到收藏夹】【关闭】
正在阅读:
Oracle SQL语言03-20
游云梦山作文350字07-05
Book 1 Unit 1 Friendship单元检测03-26
那个地方的等待作文600字06-29
静海县农业综合执法工作存在的问题及对策12-15
《新媒体营销概论》期末试卷1(含答案)08-07
2021年园林绿化品质提升年工作情况汇报08-17
资阳市2014年高中阶段教育学校招生统一考试数学试题及参考答案(03-26
中秋话相思的抒情散文03-30
荷兰的崛起,整理篇 - 图文04-11
- 多层物业服务方案
- (审判实务)习惯法与少数民族地区民间纠纷解决问题(孙 潋)
- 人教版新课标六年级下册语文全册教案
- 词语打卡
- photoshop实习报告
- 钢结构设计原理综合测试2
- 2014年期末练习题
- 高中数学中的逆向思维解题方法探讨
- 名师原创 全国通用2014-2015学年高二寒假作业 政治(一)Word版
- 北航《建筑结构检测鉴定与加固》在线作业三
- XX县卫生监督所工程建设项目可行性研究报告
- 小学四年级观察作文经典评语
- 浅谈110KV变电站电气一次设计-程泉焱(1)
- 安全员考试题库
- 国家电网公司变电运维管理规定(试行)
- 义务教育课程标准稿征求意见提纲
- 教学秘书面试技巧
- 钢结构工程施工组织设计
- 水利工程概论论文
- 09届九年级数学第四次模拟试卷
- 语言
- Oracle
- SQL
- 2013届高三物理第一轮单元能力复习题5
- 修改 2011年心肺复苏考核评分表 doc
- 苏教版三年级语文下册《海底世界》教案
- 国际3班班规
- 贵州大学“十佳大学生”评选办法及评选程序
- 2010年住院医师规范化培训公共科目试卷已整理
- 人教版七年级数学下册第七章三角形(全章) - 图文
- 第十九届科技文化艺术节通知(最后修改稿)1
- 中央国家机关文明单位申报材料 - 图文
- 企业员工培训效果评估及影响因素分析
- 黄达《金融学》(精简版) - 货币银行学 讲义2
- 吉林省吉林市第一中学校2018-2019学年高一5月月考物理(奥班)试
- 深基坑锚杆支护施工技术的应用研究
- 数学f1初中数学致远中学七年级数学国庆假期作业参考答案
- 幼儿园小班简笔画教案
- 预决算的实习周记
- 凯福德金业:欧洲央行表示未来有必要时考虑推出QE
- 2017-2018人教版二年级上册语文12坐井观天表格式教学设计 - 图文
- 专升本《西方经济学》模拟试题和答案
- 企业实施网络外贸营销秘籍