免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2703 | 回复: 5
打印 上一主题 下一主题

SQL语言简介及oracle其他应用!!---陆续更新!! [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2003-02-25 14:17 |只看该作者 |倒序浏览
正在学习oracle看到几篇有用的文章,贴给大家希望对象我这样的新手有所帮助!
1、 SQL概述
SQL是一种面向数据库的通用数据处理语言规范,能完成以下几类功能:提取查询数据,插入修改删除数据,生成修改和删除数据库对象,数据库安全控制,数据库完整性及数据保护控制。
数据库对象包括表、视图、索引、同义词、簇、触发器、函数、过程、包、数据库链、快照等(表空间、回滚段、角色、用户)。数据库通过对表的操作来管理存储在其中的数据。

1) SQL*PLUS界面:
登录:输入SQLPLUS回车;输入正确的ORACLE用户名并回车;输入用户口令并回车,显示提示符:SQL>;
退出:输入EXIT即可。
2)命令的编辑与运行:
 在命令提示符后输入SQL命令并运行,以分号结束输入;以斜杠结束输入;以空行结束输入;
 利用SQL缓冲区进行PL/SQL块的编辑和运行;
 利用命令文件进行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支持下列内部数据类型:
 VARCHAR2 变长字符串,最长为2000字符。
 NUMBER   数值型。
 LONG      变长字符数据,最长为2G字节。
 DATE       日期型。
 RAW       二进制数据,最长为255字节。
 LONG RAW  变长二进制数据,最长为2G字节。
 ROWID      二六进制串,表示表的行的唯一地址。
 CHAR       定长字符数据,最长为255。

4、 常用函数用法:
     一个函数类似于一个算符,它操作数据项,返回一个结果。函数在格式上不同于算符,它个具有变元,可操作0个、一个、二个或多个变元,形式为:
函数名(变元,变元,…)
函数具有下列一般类形:
 单行函数
 分组函数
1) 单行函数对查询的表或视图的每一行返回一个结果行。它有数值函数,字符函数,日期函数,转换函数等。
2) 分组函数返回的结果是基于行组而不是单行,所以分组函数不同于单行函数。在许多分组函数中可有下列选项:
 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;

5、 创建表、视图、索引、同义词、用户。
1) 、表是存储用户数据的基本结构。
建立表主要指定义下列信息:
 列定义
 完整性约束
 表所在表空间
 存储特性
 可选择的聚集
 从一查询获得数据
        语法如下: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简介
1、 PL/SQL概述。
PL/SQL是Oracle对SQL规范的扩展,是一种块结构语言,即构成一个PL/SQL程序的基本单位(过程、函数和无名块)是逻辑块,可包含任何数目的嵌套了快。这种程序结构支持逐步求精方法解决问题。一个块(或子块)将逻辑上相关的说明和语句组合在一起,其形式为:
DECLARE
---说明
BEGIN
---语句序列
EXCEPTION
---例外处理程序
END;
它有以下优点:
 支持SQL;
 生产率高;
 性能好;
 可称植性;
 与ORACLE集成.

2、 PL/SQL体系结构
PL/SQL运行系统是种技术,不是一种独立产品,可认为这种技术是PL/SQL块和子程序的一种机,它可接收任何有效的PL/SQL块或子程序。如图所示:













PL/SQL机可执行过程性语句,而将SQL语句发送到ORACLE服务器上的SQL语句执行器。在ORACLE预编译程序或OCI程序中可嵌入无名的PL/SQL块。如果ORACLE具有PROCEDURAL选件,有名的PL/SQL块(子程序)可单独编译,永久地存储在数据库中,准备执行。


3、 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;

4、 控制语句:
分支语句:
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;


5、 循环语句:
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;

6、 子程序:
存储过程:
CREATE PROCEDURE 过程名 (参数说明1,参数说明2, 。。。) IS
[局部说明]
BEGIN
执行语句;
END 过程名;

存储函数:
CREATE FUNCTION 函数名 (参数说明1,参数说明2, 。。。)
RETURN 类型 IS
[局部说明]
BEGIN
执行语句;
END 函数名;

论坛徽章:
0
2 [报告]
发表于 2003-02-25 14:19 |只看该作者

SQL语言简介及oracle其他应用!!---陆续更新!!

1、查看表空间的名称及大小   
select t.tablespace_name, round(sum(bytes/(1024*1024)),0) ts_size   
from dba_tablespaces t, dba_data_files d   
where t.tablespace_name = d.tablespace_name   
group by t.tablespace_name;   


2、查看表空间物理文件的名称及大小   
select tablespace_name, file_id, file_name,   
round(bytes/(1024*1024),0) total_space   
from dba_data_files   
order by tablespace_name;   


3、查看回滚段名称及大小   
select segment_name, tablespace_name, r.status,   
(initial_extent/1024) InitialExtent,(next_extent/1024) NextExtent,   
max_extents, v.curext CurExtent   
From dba_rollback_segs r, v$rollstat v   
Where r.segment_id = v.usn(+)   
order by segment_name ;   


4、查看控制文件   
select name from v$controlfile;   


5、查看日志文件   
select member from v$logfile;   


6、查看表空间的使用情况   
select sum(bytes)/(1024*1024) as free_space,tablespace_name   
from dba_free_space   
group by tablespace_name;   
SELECT A.TABLESPACE_NAME,A.BYTES TOTAL,B.BYTES USED, C.BYTES FREE,   
(B.BYTES*100)/A.BYTES "% USED",(C.BYTES*100)/A.BYTES "% FREE"   
FROM SYS.SM$TS_AVAIL A,SYS.SM$TS_USED B,SYS.SM$TS_FREE C   
WHERE A.TABLESPACE_NAME=B.TABLESPACE_NAME AND A.TABLESPACE_NAME=C.TABLESPACE_NAME;   


7、查看数据库库对象   
select owner, object_type, status, count(*) count# from all_objects group by owner, object_type, status;   


8、查看数据库的版本    
Select version FROM Product_component_version   
Where SUBSTR(PRODUCT,1,6)='Oracle';   


9、查看数据库的创建日期和归档方式   
Select Created, Log_Mode, Log_Mode From V$Database;

论坛徽章:
0
3 [报告]
发表于 2003-02-25 14:20 |只看该作者

SQL语言简介及oracle其他应用!!---陆续更新!!

以oracle身份登陆:
1.
$sqlplus /nolog
sql>;connect internal
sql>;startup

2.
$sqlplus internal
sql>;startup

3.
$sqlplus /nolog
sql>;connect /as sysdba
sql>;startup
  
4.
$svrmgr
svrmgr>;connect internal
svrmgr>;startup


数据库空间不够用可启动不起来

论坛徽章:
0
4 [报告]
发表于 2003-02-27 09:52 |只看该作者

SQL语言简介及oracle其他应用!!---陆续更新!!

1、应用开发(Application Development)

SQL*Plus E:\Oracle\Ora81\BIN\SQLPLUSW.EXE



2、数据库管理(Database Administration)

Database Configuration Assistant 数据库配置助手:创建、配置、删除数据库

DBA Studio 将多个数据库工具并入一个应用程序中。DBA Studio 管理以下对象:
例  程:包括启动、关闭和例程化例程。
方  案:包括表、索引和 Oracle8对象。
安全性:包括用户帐户、角色和权限。
存  储:包括表空间、数据文件和回退段。

SQLPlus Worksheet 类SQL*Plus的工具
E:\Oracle\Ora81\bin\oemapp.bat worksheet



3、企业管理器(Enterprise Manager)

Configuration Assistant Oracle Enterprise Manager配置辅助工具,对服务器资料档案库进行管理

Console 登录OEM管理器(Oracle Enterprise Manager)



4、移植工具(Migration Utilities)

Oracle Data Migration Assistant 移植Oracle7数据库,将Oracle8升级到Oracle8i



5、网络管理(Network Administration)

Net8 Assistant 配置网络部分(连接描述TNSNAMES.ORA、监听器LISTENER.ORA)

Net8 Configuration Assistant 功能基本同上,提供基本的配置,要获得高级配置操作,或配置此工具未包括
的 Net8 的其它部分的详细信息,请使用Net8 Assistant

Oracle ODBC Test 连接、测试Oracle ODBC的工具



6、DOS窗口下实用程序

SVRMGRL Oracle服务器管理:Oracle Server Manager
E:\Oracle\Ora81\BIN\SVRMGRL.EXE

SQL*Plus DOS窗口下使用的SQL*Plus
E:\Oracle\Ora81\BIN\SQLPLUS.EXE

LSNRCTL 监听器管理程序
E:\Oracle\Ora81\BIN\LSNRCTL.EXE

EXP/IMP 逻辑备份、恢复工具
E:\Oracle\Ora81\BIN\EXP.EXE、E:\Oracle\Ora81\BIN\IMP.EXE

SQL*Loader 大量数据插入工具
E:\Oracle\Ora81\BIN\SQLLDR.EXE

ORAPWD 修改sys或internal密码工具
E:\Oracle\Ora81\BIN\ORAPWD.EXE

OCOPY Oracle拷贝工具
E:\Oracle\Ora81\BIN\OCOPY.EXE

论坛徽章:
0
5 [报告]
发表于 2003-03-22 22:21 |只看该作者

SQL语言简介及oracle其他应用!!---陆续更新!!

oracle高级复制维护注意点 zhuantie
前段时间一致在做oracle高级复制,下面是在维护过程中对出现问题的一些分析、解决,贴出来希望对大家有帮助:

高级复制是oracle数据库的高级功能,它的维护比普通数据库复杂,下面是在已有高级复制数据库维护过程中出现过一些问题和解决办法。

1、稳定的物理链路:连接服务器的网络由于故障断开,服务器彼此之间数据就不能访问,数据无法传输;网络不稳定,数据就会发生丢包,不完整。

2、传输速度方面要求较高:否则还不如单级版本。

3、参与的服务器不能长期不开机:这样会积压大量的延迟任务,导致数据无法进行发布。

4、参与复制的表,不能在它上面直接执行任何DDL语句:因为ORACLE自动在参与复制的表上建立了内部的支持复制的TRIGGER和PACKAGE,在它上面直接执行任何DDL语句都会破坏这些复制支持。应该先SUSPEND要修改表所在的复制组,在REPICATION MANAGER中或调用REPCAT API执行DDL语句,然后重新GENERATE该表的复制支持,最后将复制组状态恢复为NORMAL。注意修改表结构的DDL语句中表名前一定要带上属主,并且最后没有分号。如果不小心直接执行了DDL语句,应该将该表移出复制环境,删掉,重新建立或从其它节点复制过来。

5、修改一张表加一个字段,并设置缺省值,如 ALTER TABLE OWNER.TABLE_NAME ADD(FIELD_NAME VARCHAR2(20) DEFAULT 'AAA');在9i之前不能一次执行,要分成两部分执行:
1、ALTER TABLE OWNER.TABLE_NAME ADD FIELD_NAME
2、ALTER TABLE OWNER.TABLE_NAME MODIFY FIELD_NAME DEFAULT 'AAA'
这是因为执行任何DDL语句,需要SUSPEND复制组,此时复制表只能查询,不能执行其它DML语句。如果直接加上一个字段同时赋予缺省值,此时的处理是加上一个字段,并立刻给该字段赋上给定的缺省值,这后面的DML语句是不能执行的,所以会报错。而分成两部分执行,第一部分先加一个字段,第二部分再修改该字段的定义,不会发生插入缺省值的DML操作,因此可以执行。

6、执行任何ADMIN REQUEST(对复制环境的管理命令)前,都要保证此时没有堆积的DEFERRED TRANS。

7、执行任何ADMIN REQUEST,必须一步一步执行。因为ADMIN REQUEST的工作原理,是用一个REPCATLOG表保存ADMIN REQUEST语句,执行完一条消失一条,后面的再继续执行。如果前面一条没执行完,后面的ADMIN REQUEST就无法执行,而REPCATLOG表如果不为空,复制组就无法恢复为NORMAL。因此每次发出ADMIN REQUEST后,都要检查REPCATLOG表,当所有节点上的REPCATLOG表都为空后,才能发出下一条命令。

8、如果发现REPCATLOG表中有无法执行的命令,可以重新APPLY或PURGE掉再重新发出命令执行。如果只是某一个节点上有遗留命令,可以在该节点上多APPLY几次执行。

9、如果发出命令后一直没有响应,而ADMIN REQUEST又无法PURGE掉,现象类似死锁。可以试着BROKEN掉该ADMIN REQUEST对应的JOB,重新刷新命令。如果命令能继续执行,恢复JOB的状态。如果还不行,从V$SESSION 和V$LOCK中查出死锁,用ALTER SYSTEM KILL SESSION 杀掉死锁的进程,如果还是杀不掉。就需要查出类型为'RQ'的分布式死锁,用SID再从V$PROCESS、V$BGPROCESS查出对应的后台进程,从操作系统级杀掉后台进程的方式来解锁,可能还需要重启数据库。最后再恢复JOB的状态和其他涉及的复制环境状态。

10、可以通过REPLICATION MANAGER或相关系统表查询复制环境情况,以REPADMIN用户登陆:
查看复制组和复制对象:
select gname,status from dba_repgroup;
--其中gname 即为复制组名,status 表示状态
select gname,oname,status from dba_repobject where type =’TABLE’ and oname =
‘table_name’;
--要查询某张表在哪个复制组中,将table_name 替换成表名,注意表名一定要大写。

查看分布式状态:
select job,what,next_sec,this_sec,last_sec,failures,broken from dba_jobs;
failures 小于16,broken 为N 表示分布式状态正常

查看数据库连接
select * from dba_db_links;

恢复传播复制任务
当连接复制环境中数据库的网络出现问题,可能会造成复制任务的停止。具体现象
表现为本地数据库的更新操作没有发布到远地数据库中。当出现这种情况时,请参考
前面提到的查看分布式状态的方法,检查复制任务是否正常。如果failures 大于等于16,
broken 为Y 表示分布式状态不正常,需要恢复传播复制任务。
exec dbms_job.run(jobno);
-- jobno 为在dba_jobs 表中ailures 大于等于16,broken 为Y 的job。

查看执行出错的事务
当分布式数据库出现不正常时,请执行下列语句,并根据查询的error_msg 来解决
问题。
select distinct origin_tran_db,destination,error_msg from deferror;

尝试执行出错的事务
根据查询的error_msg 解决了网络无法连接等问题后,请执行下列语句,并拷贝生
成的拼接exec 语句在客户端执行。
select ' exec dbms_defer_sys.execute_error ( ' ' ' || DEFERRED_TRAN_ID || ' ' ' , ' ' ' ||
DESTINATION || ' ' ' )' from deferror;

删除执行出错的事务
可能会遇到这样一种状况,尝试执行出错的事务,该事务依旧执行不成功。如果此
时deferror 表中的error_msg 都是“NO DATA FOUND”的错误,那么可以考虑删除执
行出错的事务。请特别注意,必须确认已经解决了出错原因,并在每个分布式节点都
尝试执行出错的事务后,才可以删除再次执行出错的事务,否则会造成分布式数据库
的数据不一致。
select ' exec dbms_defer_sys.delete_error ( ' ' ' || DEFERRED_TRAN_ID || ' ' ' , ' ' ' ||
DESTINATION || ' ' ' )' from deferror;

论坛徽章:
0
6 [报告]
发表于 2003-03-24 10:59 |只看该作者

SQL语言简介及oracle其他应用!!---陆续更新!!

好!支持!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP