




已阅读5页,还剩5页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Oracle SQL语言 作者:jimijiao发表于:2003-09-17 14:17:11数据库对象包括表、视图、索引、同义词、簇、触发器、函数、过程、包、数据库链、快照等(表空间、回滚段、角色、用户)。数据库通过对表的操作来管理存储在其中的数据。 SQL*PLUS界面: 登录:输入SQLPLUS回车;输入正确的ORACLE用户名并回车;输入用户口令并回车,显示提示符:SQL 退出:输入EXIT即可。 2)命令的编辑与运行: 在命令提示符后输入SQL命令并运行,以分号结束输入;以斜杠结束输入;以空行结束输入; 利用SQL缓冲区进行PL/SQL块的编辑和运行; 利用命令文件进行PL/SQL块的编辑和运行。 数据库查询 用SELECT语句从表中提取查询数据。语法为 SELECTDISTINCTcolumn1,column2,FROMtablenameWHEREconditionsGROUPBYconditionsORDERBYexpressionsASC/DESC; 说明:SELECT子句用于指定检索数据库的中哪些列,FROM子句用于指定从哪一个表或视图中检索数据。 SELECT中的操作符及多表查询WHERE子句。(LIKE,IS,) WHERE子句中的条件可以是一个包含等号或不等号的条件表达式,也可以是一个含有IN、NOTIN、BETWEEN、LIKE、ISNOTNULL等比较运算符的条件式,还可以是由单一的条件表达通过逻辑运算符组合成复合条件。 ORDERBY子句 ORDERBY子句使得SQL在显示查询结果时将各返回行按顺序排列,返回行的排列顺序由ORDERBY子句指定的表达式的值确定。 连接查询 利用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字节。 LONGRAW变长二进制数据,最长为2G字节。 ROWID二六进制串,表示表的行的唯一地址。 CHAR定长字符数据,最长为255。 常用函数用法: 一个函数类似于一个算符,它操作数据项,返回一个结果。函数在格式上不同于算符,它个具有变元,可操作0个、一个、二个或多个变元,形式为: 函数名(变元,变元,) 函数具有下列一般类形: 单行函数 分组函数 单行函数对查询的表或视图的每一行返回一个结果行。它有数值函数,字符函数,日期函数,转换函数等。 分组函数返回的结果是基于行组而不是单行,所以分组函数不同于单行函数。在许多分组函数中可有下列选项: DISTRNCT该选项使分组函数只考虑变元表达式中的不同值。 ALL该选项使分组函数考虑全部值,包含全部重复。 全部分组函数(除COUNT(*)外)忽略空值。如果具有分组函数的查询,没有返回行或只有空值(分组函数的变元取值的行),则分组函数返回空值。 5、数据操纵语言命令: 数据库操纵语言(DML)命令用于查询和操纵模式对象中的数据,它不隐式地提交当前事务。它包含UPDATE、INSERT、DELETE、EXPLAINPLAN、SELECT和LOCKTABLE等命令。下面简单介绍一下: 1)UPDATEtablenameSETcolumn1=expression1,column2=expression2,WHEREconditions; 例如:S QLUPDATEEMP SETJOB=MANAGER WHEREENAME=MAPTIN; SQLSELECT*FROMEMP; UPDATE子句指明了要修改的数据库是EMP,并用WHERE子句限制了只对名字(ENAME)为MARTIN的职工的数据进行修改,SET子句则说明修改的方式,即把MARTION的工作名称(JOB)改为MARAGER. 2)INSERTINTOtablenamecolumn1,column2,VALUESexpression1,expression2,; 例如:SQLSELECTINTODEPT(DNAME,DEPTNO) VALUES(ACCOUNTING,10) 3)DELETEFROMtablenameWHEREconditions; 例如:SQLDELETEFROMEMP WHEREEMPNO=7654; DELETE命令删除一条记录,而且DELETE命令只能删除整行,而不能删除某行中的部分数据. 4)事务控制命令 提交命令(COMMIT):可以使数据库的修改永久化.设置AUTOCOMMIT为允许状态:SQLSETAUTOCOMMITON; 回滚命令(ROLLBACK):消除上一个COMMIT命令后的所做的全部修改,使得数据库的内容恢复到上一个COMMIT执行后的状态.使用方法是: SQLROLLBACK; 创建表、视图、索引、同义词、用户。 、表是存储用户数据的基本结构。 建立表主要指定义下列信息: 列定义 完整性约束 表所在表空间 存储特性 可选择的聚集 从一查询获得数据 语法如下:CREATETABLEtablename (column1datatypeDEFAULTexpressionconstraint, column1datatypeDEFAULTexpressionconstraint, ) STORAGE子句 其他子句; 例如: SQLCREATETABLENEW_DEPT (DPTNONUMBER(2), DNAMECHAR(6), LOCCHAR(13); 更改表作用: 增加列 增加完整性约束 重新定义列(数据类型、长度、缺省值) 修改存储参数或其它参数 使能、使不能或删除一完整性约束或触发器 显式地分配一个范围 2)、视图 视图是一个逻辑表,它允许操作者从其它表或视图存取数据,视图本身不包含数据。视图所基于的表称为基表。 引入视图有下列作用: 提供附加的表安全级,限制存取基表的行或/和列集合。 隐藏数据复杂性。 为数据提供另一种观点。 促使ORACLE的某些操作在包含视图的数据库上执行,而不在另一个数据库上执行。 3)、索引 索引是种数据库对象。对于在表或聚集的索引列上的每一值将包含一项,为行提供直接的快速存取。在下列情况ORACLE可利用索引改进性能: 按指定的索引列的值查找行。 按索引列的顺序存取表。 建立索引:CREATEUNIQUEINDEXindexnameONtablename(column,。); 例如:SQLCREATINDEXIC_EMP ONCLUSTEREMPLOYEE 4)、同义词 同义词:为表、视图、序列、存储函数、包、快照或其它同义词的另一个名字。使用同义词为了安全和方便。对一对象建立同义词可有下列好处: 引用对象不需指出对象的持有者。 引用对象不需指出它所位于的数据库。 为对象提供另一个名字。 建立同义词: CREATESYNONYMsymnon_nameFORusername.tablename; 例如:CREATPUBLICSYNONYMEMP FORSCOTT.EMPSALES 5)、用户 CREATEUSERusernameIDENTIFIEDBYpassword; 例如:SQLCREATEUSERSIDNEY IDENTIFIEDBYCARTON; 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预编译程序或OCI程序中可嵌入无名的PL/SQL块。如果ORACLE具有PROCEDURAL选件,有名的PL/SQL块(子程序)可单独编译,永久地存储在数据库中,准备执行。 PL/SQL基础: PL/SQL有一字符集、保留字、标点、数据类型、严密语法等,它与SQL有相同表示,现重点介绍。 1)、数据类型:如下表所示 数据类型 子类型 纯量类型 数值 BINARY_INTEGER NATURAL,POSITIVE NUMBER DEC,DECIMAL,DOUBLEPRECISION,PLOAT,INTEGER,INT,NUMERIC,REAL,SMALLINT 字符 CHAR CHARACTER,STRING VARCHAR2 VARCHAR LONG LONGRAW RAW RAWID 逻辑 BOOLEAN 日期 DATE 组合类型 记录 RECORD 表 TABLE 2)、变量和常量 在PL/SQL程序中可将值存储在变量和常量中,当程序执行时,变量的值可以改变,而常量的值不能改变。 3)、程序块式结构: DECLARE 变量说明部分; BEGIN 执行语句部分; EXCEPTION 例外处理部分; END; 控制语句: 分支语句: IFconditionTHEN Sequence_of_statements; ENDIF; IFconditionTHEN Sequence_of_statement1; ELSE Sequence_of_statement2; ENDIF; IFcondition1THEN Sequence_of_statement1; ELSIFcondition2THEN Sequence_of_statement2; ELSIFcondition3THEN Sequence_of_statement3; ENDIF; 循环语句: LOOP Sequence_of_statements; IFconditionTHEN EXIT; ENDIF; ENDLOOP; WHILEconditionLOOP Sequence_of_statements; ENDLOOP; FORcounterINlower_bound.higher_boundLOOP Sequence_of_statements; ENDLOOP; 子程序: 存储过程: CREATEPROCEDURE过程名(参数说明1,参数说明2,。)IS 局部说明 BEGIN 执行语句; END过程名; 存储函数: CREATEFUNCTION函数名(参数说明1,参数说明2,。) RETURN类型IS 局部说明 BEGIN 执行语句; END函数名;truncate,delete,drop的异同点 作者: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,这个操作会放到rollbacksegement中,事务提交之后才生效;如果有相应的trigger,执行的时候将被触发. truncate,drop是ddl,操作立即生效,原数据不放到rollbacksegment中,不能回滚.操作不触发trigger. 3.delete语句不影响表所占用的extent,高水线(highwatermark)保持原位置不动 显然drop语句将表所占用的空间全部释放 truncate语句缺省情况下见空间释放到minextents个extent,除非使用reusestorage;truncate会将高水线复位(回到最开始). 4.速度,一般来说:droptruncatedelete 5.安全性:小心使用drop和truncate,尤其没有备份的时候.否则哭都来不及 使用上,想删除部分数据行用delete,注意带上where子句.回滚段要足够大. 想删除表,当然用drop 想保留表而将所有数据删除.如果和事务无关,用truncate即可.如果和事务有关,或者想触发trigger,还是用delete. 如果是整理表内部的碎片,可以用truncate跟上reusestroage,再重新导入/插入数据 个人总结,欢迎大家补充【发表回复】【查看论坛原帖】【添加到收藏夹】【关闭】 SQL*PLUS常用命令列表 作者:horse发表于:2003-12-17 18:51:24color=blue:557795a379size=18:557795a379命令列表/size:557795a379/color:557795a379: 假设当前执行命令为:select*fromtab; (a)ppend添加文本到缓冲区当前行尾aorderbytname结果:select*fromtaborderbytname; (注:a后面跟2个空格) (c)hange/old/new在当前行用新的文本替换旧的文本c/*/tname结果:selecttnamefromtab; (c)hange/text从当前行删除文本c/tab结果:selecttnamefrom; del删除当前行 deln删除第n行 (i)nput文本在当前行之后添加一行 (l)ist显示缓冲区中所有行 (l)istn显示缓冲区中第n行 (l)istmn显示缓冲区中m到n行 run
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 美术中考加试题目及答案
- 激光技术工程师考试关注要点试题及答案
- 药物与公共卫生的关系考核试题及答案
- 自尊心的构建与维护试题及答案
- 护理学基础知识的重要性分析试题及答案
- 网络规划设计工具的熟练使用试题及答案
- 国际专利市场的变化与趋势试题及答案
- 民间刺客面试题及答案
- 激光在复合材料加工中的应用试题及答案
- 蒙城护士考试试题及答案
- 能源中国学习通章节答案期末考试题库2023年
- 刮痧技术操作流程图
- ISO9001 2015版质量管理体系标准
- 山西省博物院讲解词(全)
- 部编版《语文》三年级下册全册教案及反思
- 自考07887平面设计(12-19)真题试卷
- 高大模板工程验收表
- (中职)Photoshop基础实用教程全册教案2022-2023学年
- 酒店旅馆防偷拍摄像头排查指引
- GB/T 21655.2-2019纺织品吸湿速干性的评定第2部分:动态水分传递法
- 电力工程标准规范清单(2023年3月份)
评论
0/150
提交评论