400 likes | 526 Views
Oracle9i常用工具. 第八章 Oracle9i 常用工具. 本章学习目标 本章将介绍其中最常用的SQL*Plus、Oracle Enterprise Manager、数据库移植助手、Oracle Net、LogMiner等工具。. 本章内容安排. 8.1 SQL*Plus交互式应用程序. 8.2 SQL*Plus Worksheet全屏幕开发环境. 8.3 Oracle 企业管理器( OEM ). 8.4 移植工具. 8.5 网络管理. 8.6 性能监测器. 8.7 分析工具LogMiner. 8.1 SQL*Plus交互式应用程序.
E N D
第八章 Oracle9i常用工具 本章学习目标 本章将介绍其中最常用的SQL*Plus、Oracle Enterprise Manager、数据库移植助手、Oracle Net、LogMiner等工具。
本章内容安排 8.1 SQL*Plus交互式应用程序 8.2 SQL*Plus Worksheet全屏幕开发环境 8.3 Oracle企业管理器(OEM) 8.4 移植工具 8.5 网络管理 8.6 性能监测器 8.7 分析工具LogMiner
8.1 SQL*Plus交互式应用程序 8.1.1 SQL*Plus的启动和关闭 8.1.2 SQL* Plus命令
8.1.1 SQL*Plus的启动和关闭 1.SQL*Plus的启动 (1)SQL*Plus注册对话框窗口说明 (2)SQL*Plus的编辑窗口说明 (3)SQL*Plus窗口命令应用方式 (4)SQL*Plus环境设置对话框窗口说明
2.SQL*Plus的关闭 结束SQL*Plus会话的方法有两种: ①直接关闭窗口; ②在SQL>提示符后键入并执行EXIT命令,窗口自动关闭。
8.1.2 SQL* Plus命令 1.查看、编辑和运行SQL* Plus缓冲区内容的命令 表8-1 查看、编辑和运行SQL* Plus缓冲区内容的命令 2.文件管理命令 下面列出了在SQL*Plus中使用这三个命令的经过,如下所示: SQL>save file1 己创建文件file1。 SQL>get file1 select name,gender from hxh where operatorno=1 //file1的语句 SQL>@ file1 NAME GENDER //显示查询结果 Oracl male
3.数据拷贝命令 COPY命令用来将数据从指定的数据库拷贝到另一个数据库,可以实现下面的几个功能: ①从一个本地数据库将一个或多个表或整个模式拷贝到一个远程数据库或另外一个本地数据库。这可以用于从一个数据库将整个模式移动到另外一个数据库,而不需要使用导出导入工具,当导出大于操作系统文件限制的文件时尤其有用。 ②将一个表中指定的记录(基于查询)拷贝到远程数据库或本地数据库的其他表中。 ③将包含LONG类型数据列的表的内容拷贝到其他表。因为LONG类型的列不能用于SELECT语句中,所以这是解决此问题的唯一方法。 ④从一个Oracle数据库向一个非Oracle数据库拷贝表。
数据拷贝命令的格式如下: COPY[FROM<用户名>/<口令>@<数据库>= [TO<用户名>/<口令>@<数据库>] {APPEND |CREATE | INSERT | REPLACE} <表>[(<列>,…==USING<查询>
如果目标表存在,APPEND便将查询出的记录插入到目标表。即使该表为空(不含数据),APPEND命令也能插入记录。如果目标表存在,APPEND便将查询出的记录插入到目标表。即使该表为空(不含数据),APPEND命令也能插入记录。 • CREATE创建新表,然后向目标表中插入取自查询的记录。如果目标表已经存在,COPY命令就会返回一个错误。 • INSERT将取自查询的记录插入目标表。如果目标表不存在,COPY命令就会返回错误。 • REPLACE使用查询提取的记录替换目标表及其内容。如果目标表存在,COPY就会删除它并用含有拷贝数据的表替换它。
4.格式化报表 5.注册、释放和退出 6.设置SQL*Plus的系统环境变量 7.其他命令
8.2 SQL*Plus Worksheet全屏幕开发环境 8.2.1 SQL*Plus Worksheet和SQL*Plus的比较 8.2.2 SQL*Plus Worksheet的使用
8.2.1 SQL*Plus Worksheet和SQL*Plus的比较 SQL*Plus和SQL*Plus Worksheet都是开发环境和工具。在两种环境中都可以使用PL/SQL语句,实现对数据库数据的操作和控制,区别是SQL*Plus是行编辑环境,在SQL*Plus环境中有一系列支持行编辑的命令。而SQL*Plus Worksheet是全屏幕的编程和运行环境,可以直接编辑PL/SQL命令或程序文件。所以,比较而言,SQL*Plus Worksheet使用更简单、方便。
8.2.2 SQL*Plus Worksheet的使用 1.启动SQL*Plus Worksheet 2.使用SQL*Plus Worksheet
1、启动SQL*Plus Worksheet (1)直接登录进入 直接登录进入的操作步骤为: 在Oracle菜单中运行“Application Development”→“SQLPlus Worksheet”,进入登录对话框. (2)由Oracle企业管理器控制台OEMC进入 由OEMC进入的操作步骤为:在Oracle菜单中运行“Oracle Enterprise Manager Console”,打开Oracle Enterprise Manager Console控制台,进入SQL*Plus工作单,选择菜单的“工具”→“数据库应用程序” →“SQL*Plus Worksheet”,打开工作单窗口。
2.使用SQL*Plus Worksheet (1)窗口上部是全屏幕编辑区域,可以键入或导入以及编辑PL/SQL语句或程序。 (2)窗口的下部是语句或程序的运行结果显示区域。 (3)窗口左侧边框中有一工具栏,包括五个工具按钮,按钮自上而下依次为: ①改变数据库连接按钮:改变当前连接的数据库。 ②执行按钮:开始执行命令区输入的语句或程序。 ③语句历史记录按钮:打开 “显示历史记录”对话框,从该对话框中可选择前面键入过的语句,然后单击“获取”按钮,重新执行该语句。可以避免语句重复输入,提高操作效率。 ④帮助按钮:可获得联机帮助提示。 ⑤速成教学按钮:打开Oracle9i的速成教学文档,学习或查找相关信息。
8.3 Oracle企业管理器(OEM) 8.3.1 OEM的体系结构 8.3.2 OEM组件介绍
8.3.1 OEM的体系结构 OEM为三层结构,其组成如下: (1)第一层是客户端工具,如:EM Console, DBA Management Pack和其他集成的Oracle应用。这些工具是从机器本地启动的。也可以是通过浏览器下载下来的JAVA applet。
(2)第二层,也就是中间层,由安装在操作系统上的Oracle Management Server(OMS)构成。很多工具都要求先配置好OMS。 OMS提供了: ①访问EM库(Repository)中的信息。 ②分派控制台的请求。 ③控制任务执行。 ④监控事件。 ⑤通过电子邮件或寻呼提示任务的完成或事件发生。 多个OMS能够提供: ①无需额外的管理,就可以实现负载的分布。 ②工作量能够自动地被共享和均衡。 ③容错,一个OMS可以重做另外一个OMS的工作量。
(3)第三层是智能代理(Intelligent Agent),是在每个server上必须安装的,用来执行任务和监控发生在该服务器各被管理对象上的事件的软件。被管理对象包括网络节点(服务器)、数据库、侦听程序(listener)以及其他安装在这些结点上的Oracle服务。
8.3.2 OEM组件介绍 1.方案管理 方案管理能够在数据库中管理对象。可以用于创建、修改和删除tables、indexes、views、snapshots、sequences等。 方案管理功能非常强大,能够以层次结构列表形式管理。 方案管理器提供了许多有关管理模式对象的能力。数据库系统管理员可以创建任意的管理对象,甚至可以使用现有的对象作为模板。
2.安全管理 安全管理提供给数据库系统管理员在Oracle中管理访问权限和对象权限的一种方法。数据库系统管理员能够为用户和其他角色创建、修改和删除安全对象以及相关的权限、角色、限额和环境资源文件。 安全管理非常易于使用,可以将它提供给终端用户安全管理员用于管理应用安全。这些终端用户安全管理员拥有在他们职责范围之内对角色和对象的ADMIN OPTION授权的权力。通过合理地使用角色、进行应用用户训练和使用安全管理器,可以避免使用执行该功能的自定义应用组件。
3.存储管理 存储管理允许创建和修改表空间,数据文件和回滚段。 4.例程管理 例程管理允许关闭,启动例程并且存储和管理数据库参数。例程管理提供了大量有关数据库可用性管理的功能。例程管理监测每个数据库的例程,并显示例程启动参数状态。如果数据库在运行,则可以看到所有当前的连接。可以临时打开自动归档(直到例程完成)或触发等几种类型的手工归档。通过在导航窗口选定数据库对象,可以得到数据库状态的信息、日志记录状态和SGA配置信息。
5.复制管理 复制管理允许用户对数据库和对象进行复制。
8.4 移植工具 Oracle Data Migration Assistant是Oracle数据库中的移植工具。可以移植Oracle7数据库,并将Oracle8升级到Oracle9i。
8.5 网络管理 Oracle Net Assistant 配置网络管理部分,在Oracle Net Assistant配置中可以对Net的概要文件、服务命名、监听程序等进行配置。 Net Configuration Assistant 功能基本上与Oracle Net Assistant的功能相同。提供基本的配置,如监听程序,命名方法等,要获得高级配置操作,或配置此工具未包括的 Net 的其它部分的详细信息,请使用Net Assistant Oracle ODBC Test 连接、测试Oracle ODBC的工具。
8.6 性能监测器 利用Oracle中所带的性能监测器可以监测数据库系统的活动。利用它可以检查CPU的使用以及数据库文件的IO活动。监测可以显示图和图表以及生成报表等等。
8.7 分析工具LogMiner 8.7.1 LogMiner的用途 8.7.2 LogMiner的安装和使用 8.7.3 图形化分析工具
8.7.1 LogMiner的用途 1.LogMiner的主要用途 LogMiner工具的主要用途有: (1)跟踪数据库的变化:可以离线的跟踪数据库的变化,而不会影响在线系统的性能。 (2)回退数据库的变化:回退特定的变化数据,减少point-in-time recovery的执行。 (3)优化和扩容计划:可通过分析日志文件中的数据以分析数据增长模式。
2.Oracle9i LogMiner的增强功能 (1)支持更多数据/存储类型:链接/迁移行、CLUSTER表操作、DIRECT PATH插入以及DDL操作。 (2)提取和使用数据字典的选项:现在数据字典不仅可以提取到一个外部文件中,还可以直接提取到重做日志流中,它在日志流中提供了操作当时的数据字典快照,这样就可以实现离线分析。 (3)允许对DML操作按事务进行分组:可以在START_LOGMNR()中设置COMMITTED_DATA_ONLY选项,实现对DML操作的分组,这样将按SCN的顺序返回已经提交的事务。
(4)支持SCHEMA的变化:在数据库打开的状态下,如果使用了LogMiner的DDL_DICT_TRACKING选项,Oracle9i的LogMiner将自动对比最初的日志流和当前系统的数据字典,并返回正确的DDL语句,并且会自动侦察并标记当前数据字典和最初日志流之间的差别,这样即使最初日志流中所涉及的表已经被更改或者根本已经不存在,LogMiner同样会返回正确的DDL语句。(4)支持SCHEMA的变化:在数据库打开的状态下,如果使用了LogMiner的DDL_DICT_TRACKING选项,Oracle9i的LogMiner将自动对比最初的日志流和当前系统的数据字典,并返回正确的DDL语句,并且会自动侦察并标记当前数据字典和最初日志流之间的差别,这样即使最初日志流中所涉及的表已经被更改或者根本已经不存在,LogMiner同样会返回正确的DDL语句。 (5)在日志中记录更多列信息的能力:例如对于UPDATE操作不仅会记录被更新行的情况,还可以捕捉更多已发生的更新操作信息。 (6)支持基于数值的查询:Oracle9i LogMiner在支持原有基于元数据(操作、对象等)查询的基础上,开始支持基于实际涉及到的数据的查询。例如涉及一个工资表,现在可以很容易地查出员工工资由1000变成2000的原始更新语句,而在之前只能选出所有的更新语句。
8.7.2 LogMiner的安装和使用 1.LogMiner的安装 2.LogMiner工具的使用 3.其他注意事项
1. LogMiner的安装 要安装LogMiner工具,必须首先要以SYS用户身份运行下面两个脚本文件: (l)$Oracle_HOME/rdbms/admin/dbmslsm.sql 用来创建DBMS_LOGMNR包,该包用来分析日志文件。 (2)$Oracle_HOME/rdbms/admin/dbmslsmd.sql 用来创建DBMS_LOGMNR_D包,该包用来创建数据字典文件。
2. LogMiner工具的使用 (1)创建数据字典文件(data-dictionary) 创建数据字典的目的就是让LogMiner引用涉及到内部数据字典中的部分时为他们实际的名字,而不是系统内部的16进制。数据字典文件是一个文本文件,使用包DBMS_LOGMNR_D来创建。 首先在init.ora初始化参数文件中,指定数据字典文件的位置,也就是添加一个参数UTL_FILE_DIR,该参数值为服务器中放置数据字典文件的目录。如: UTL_FILE_DIR=e:\Oracle\logs; 重新启动数据库,使新加的参数生效,然后创建数据字典文件: CONNECT SYS EXECUTE dbms_logmnr_d.build( dictionary_filename=>'v816dict.ora', dictionary_location=>'e:\oracle\logs');
(2)创建要分析的日志文件列表 Oracle的重作日志分为两种,在线(online)和离线(offline)归档日志文件,下面就分别来讨论这两种不同日志文件的列表创建。 ①分析在线重作日志文件 ● 创建列表 EXECUTE dbms_logmnr.add_logfile( LogFileName=>'e:\Oracle\oradata\sxf\redo01.log', Options=>dbms_logmnr.new); ● 添加其他日志文件到列表 EXECUTE dbms_logmnr.add_logfile( LogFileName=>'e:\Oracle\oradata\sxf\redo02.log', Options=>dbms_logmnr.addfile);
②分析离线日志文件 ● 创建列表 EXECUTE dbms_logmnr.add_logfile( LogFileName=>'E:\Oracle\oradata\sxf\archive\ARCARC09108.001',Options=>dbms_logmnr.new); ● 添加另外的日志文件到列表 EXECUTE dbms_logmnr.add_logfile( LogFileName=>'E:\Oracle\oradata\sxf\archive\ARCARC09109.001',Options=>dbms_logmnr.addfile);
(3)使用LogMiner进行日志分析 ①无限制条件 EXECUTE dbms_logmnr.start_logmnr( DictFileName=>'e:\oracle\logs\v816dict.ora'); ②有限制条件 通过对过程DBMS_ LOGMNR.START_LOGMNR中几个不同参数的设置,可以缩小要分析日志文件的范围。通过设置起始时间和终止时间参数可以限制只分析某一时间范围的日志。
(4)观察分析结果(v$logmnr_contents) 动态性能视图v$logmnr_contents包含LogMiner分析后得到的所有的信息。 与日志分析相关视图还有: ①V$LOGMNR_DICTIONARY:查询使用的数据字典文件。 ②V$LOGMNR_PARAMETERS:查询当前LogMiner设定的参数。 ③V$LOGMNR_FILES:查询分析的日志文件。 ④V$LOGMNR_CONTENTS:日志文件的内容。
3.其他注意事项 (1)LogMiner必须使用被分析数据库实例产生的字典文件,而不是安装LogMiner的数据库产生的字典文件,另外必须保证安装LogMiner数据库的字符集和被分析数据库的字符集相同。 (2)被分析数据库平台必须和当前LogMiner所在数据库平台一样。 (3)LogMiner日志分析工具仅能够分析Oracle 8以后的产品。
8.7.3 图形化分析工具 Oracle还提供了用来分析数据库对象的图形化工具。