1、本章知识要点:本章知识要点:参数文件的类型常用的参数创建参数文件显示和设置初始化参数文件启动数据库的步骤启动模式转换启动模式数据库的关闭步骤各种关闭数据库的方式数据库的特殊状态启动与关闭数据库服务13.1 管理初始化参数管理初始化参数 初始化参数用于设置实例和数据库的特征。通过设置初始化参数,不仅可以定义例程和数据库特征,还可以定义许多其他特征和限制。例如,通过使用初始化参数,可以定义SGA尺寸,设置数据库名称,定义用户和进程限制,定义控制文件,跟踪文件和警告日志的位置等。在Oracle数据库中,初始化参数是存储在参数文件中的,启动实例、打开数据库时都必须提供相应的参数文件。23.1.1 常用
2、初始化参数常用初始化参数 Oracle 11g提供了200多个初始化参数,并且多数初始化参数都具有默认值。使用Oracle数据库时,只需要根据特定需求设置相应的参数即可,并且多数参数都可以保留默认值。从ORACLE 8I开始,可以通过ALTER SYSTEM(ALTER SESSION)修改初始化参数。不保存在初始化参数文件里。Oracle 9i开始提供 服务器端初始化参数文件(spfile)33.1.2 初始化参数文件初始化参数文件 在传统上,Oracle在启动实例时将读取本地的一个文本文件,并利用从中获取初始化参数对实例和数据库进行设置,这个文本文件称为初始化参数文件(简称为PFILE)。
3、如果要对初始化参数进行修改,必须先关闭数据库,然后在初始化参数文件中进行编辑,再重新启动数据库使修改生效。43.1.3 创建初始化参数文件创建初始化参数文件 如果当前实例正在使用SPFILE,那么使用ALTER SYSTEM命令将无法修改某些初始化参数,如DB_NAME。为了修改这些初始化参数,必须建立PFILE,并且手工修改该PFILE文件的相应参数。可以使用CREATE PFILE命令可以建立文本参数文件,其语法如下:5create pfile=pfile_name from spfile=spfile_name3.1.4 显示和设置初始化参数文件显示和设置初始化参数文件 为了显示所有初始
4、化参数的位置,可以直接执行SHOW PARAMETER命令。例如:6SQLshow parameterNAME TYPE VALUE-db_writer_processes integer 1dbwr_io_slaves integer 0ddl_lock_timeout integer 0dg_broker_config_file1 string D:APPMANAGERPRODUCT11.1.0 DB_1DATABASEDR1ORCL.DATdg_broker_config_file2 string D:APPMANAGERPRODUCT11.1.0 DB_1DATABASEDR2ORCL
5、.DATdg_broker_start boolean FALSE.3.1.4 显示和设置初始化参数文件显示和设置初始化参数文件 ALTER SYSTEM语句时,可以在SET字句中通过SCOPE选项来设置语句的影响范围。SCOPE=MEMORY 对参数的修改记录在内存。动态参数,立即生效。静态参数不能使用该选项。SCOPE=SPFILE 修改记录在SPFILE中。修改后的参数在下一次启动数据库时生效。SCOPE=BOTH 两者这和。默认选项。73.2 启动数据库与实例启动数据库与实例 由于Oracle数据库的启动过程是分步进行的,因此数据库可以有多种模式启动。不同的启动模式之间能够相互切换。此
6、外,除正常方式启动数据库外,还能够将数据库设置为受限状态或只读状态,以满足特殊管理工作的需要。83.2.1 启动数据库的步骤启动数据库的步骤 由于实例是Oracle用来管理数据库的一个实体,在启动数据库时将在内存中创建与该数据库所对应的实例。Oracle数据库的完整启动过程分为如下3个步骤:1.创建并启动与数据库对应的实例。创建并启动与数据库对应的实例。启动后台进程和服务进程,创建SGA等内存结构。只使用参数文件参数文件。2.为实例加载数据库为实例加载数据库。打开控制文件控制文件,获取数据库名称,数据库文件位置等有关物理结构的信息。不打开数据文件和日志文件。3.将数据库设置为打开状态。将数据库
7、设置为打开状态。打开联机数据文件和日志文件数据文件和日志文件。93.2.2 启动模式启动模式 由上面的介绍可知,数据库和实例的启动过程可以分为3个步骤:启动实例,加载数据库,打开数据库。数据库管理员可以根据实际情况的需要,以不同的模式启动数据库。启动数据库所使用的STARTUP命令格式如下:startup nomount 启动实例不加载数据库 startup mount 加载数据库但不打开数据库 startup 打开数据库 startup force强制启动数据库 10startup nomount|mount|open|force resetrict pfile=filename3.2.2
8、启动模式(启动模式(NOMOUNT)startup nomount 创建实例,并不加载数据库。启动模式中第一步骤 一般用途:创建新数据库 重建控制文件11SQLshutdown immediate数据库已经关闭。已经卸载数据库。ORACLE例程已经关闭。SQLstartup nomountORACLE 例程已经启动。3.2.2 启动模式(启动模式(MOUNT)startup mount 加载数据库但不打开数据库。启动模式中第二步骤 一般用途:重命名数据文件。添加、删除或重命名重做日志文件 执行数据库完全恢复操作 改变数据库的归档模式12SQLshutdown immediate数据库已经关闭。
9、已经卸载数据库。ORACLE例程已经关闭。SQLstartup mountORACLE 例程已经启动。3.2.3 转换启动模式转换启动模式 在进行某些特定的管理和维护操作时,需要使用某种特定的启动模式来启动数据库。但是当管理或维护操作完成后,需要改变数据库的启动模式。例如,为一个未加载数据库的实例加载数据库,或者将一个处于未打开状态的数据库设置为打开状态等。13SQL startup nomountORACLE 例程已经启动。Total System Global Area 376635392 bytesFixed Size 1333312 bytesVariable Size 3103804
10、80 bytesDatabase Buffers 58720256 bytesRedo Buffers 6201344 bytesSQL alter database mount;-加载数据库数据库已更改。SQL alter database open;-打开数据库数据库已更改。3.2.3 转换启动模式(转换启动模式(受限状态)在正常启动模式下(OPEN),可以选择将数据库设置为非受限状态和受限状态。在受限状态下,只有具有权限的用户才能访问数据库。以下维护操作时,需将数据库设置为受限状态。u执行数据导入或导出操作u暂时拒绝普通用户访问数据库u进行数据库移植或升级操作14SQL startup
11、restrictSQL alter system disable restricted session;-非受限状态SQL alter system enable restricted session;-受限状态3.2.3 转换启动模式(转换启动模式(只读状态)在正常启动模式下(OPEN),可以选择将数据库设置为只读状态。在只读状态下,用户只能查询数据库,不能以任何方式对数据库对象进行修改15SQL startup mountSQL alter database open read only;-只读状态SQL alter database open read write;-读写状态3.3 关闭
12、数据库与实例关闭数据库与实例 与数据库的启动相对应,关闭数据库时也是分步骤进行的。在关闭数据库与实例时,需要使用一个具有SYSDBA权限的用户账户连接到Oracle中,然后使用SHUTDOWN语句执行关闭操作。163.3.1 数据库的关闭步骤数据库的关闭步骤 与启动数据库实例的3个步骤相同,关闭数据库与实例也可以分为3步:关闭数据,实例卸载数据库,最后终止实例。17shutdown normal|transactional|immediate|abort3.3.2 正常关闭方式(正常关闭方式(NORMAL)如果对关闭数据库的时间没有限制,通常会使用正常方式来关闭数据库。使用带有NORMAL子句
13、的SHTUDOWN语句将以正常方式关闭数据库,下面显示了在SQL*Plus中以正常方式关闭过程:1.阻止任何用户建立新的连接2.等待当前所有正在连接的用户主动断开连接,已经连接的用户可以继续当前的操作。3.一旦所有用户都断开联机,则立即关闭、卸载数据库,终止实例。18SQL shutdown normal数据库已经关闭。已经卸载数据库。ORACLE 例程已经关闭。3.3.3 立即关闭方式(立即关闭方式(IMMEDIATE)立即方式能够在尽可能短的时间内关闭数据库。以立即方式关闭数据库时,Oracle将执行如下操作:1.阻止任何用户建立新的连接,同时阻止当前连接的用户开始任何新的事务。2.任何未
14、提交的事务均被回退。3.Oracle不再等待用户主动断开连接,而是直接关闭、卸载数据库,并终止实例。19SQL shutdown immediate数据库已经关闭。已经卸载数据库。ORACLE 例程已经关闭。3.3.4 事务关闭方式事务关闭方式(TRANSACTIONAL)事务方式介于正常关闭方式与立即关闭方式之间,它能够在尽可能短的时间内关闭数据库,但是能够保证当前所有的活动事务都可以被提交。使用事务方式关闭数据库时,Oracle将等待所有未提交的事务完成后再关闭数据库。1.阻止任何用户建立新的连接,同时阻当前联机的用户开始任何新的事务。2.等待所有未提交的活动事务提交完毕,然后立即断开用户
15、的连接。3.关闭、卸载数据库,并终止实例20SQL shutdown transactional数据库已经关闭。已经卸载数据库。ORACLE 例程已经关闭。3.3.5 终止关闭方式(终止关闭方式(ABORT)如果上述三种关闭方式都无法关闭数据库,说明数据库产生了严重的错误,这时只能使用终止方式来关闭数据库。终止关闭方式将丢失一部分数据信息,会对数据库的完整性造成损害。因此,如果重新启动实例并打开数据库时,后台进程SMON会执行实例恢复。一般情况下,应当尽量避免使用这种方式来关闭数据库。1.阻止任何用户建立新的连接,同时阻止当前连接的用户开始任何新的事务2.立即终止当前正在执行的SQL语句3.任
16、何未提交的事务均不被回退4.立即断开所有用户的连接,关闭、卸载数据库,终止实例213.4 数据库的特殊状态数据库的特殊状态 静默状态和挂起状态是两种特殊的数据库状态。当数据库处理静默状态时,只有SYS和SYSTEM用户能够在数据库中进行操作。当数据库处于挂起状态时,数据库I/O操作都会被暂时停止。利用这两种数据库状态,数据库管理员可以完成一些特殊的管理和维护操作。223.4.1 静默状态静默状态 在静默状态下,只有具有管理员权限的用户才能够在数据库中执行查询、更新操作,运行PL/SQL程序,任何非管理员用户都不能在数据库中执行任何操作。在数据库运行过程中,执行如下的语句将进入静默状态:23进入
17、静默状态SQL alter system quiesce restricted;系统已更改。恢复正常SQL alter system unquiesce;系统已更改。查询状态SQLselect instance_name,active_state from v$instance;3.4.2 挂起状态挂起状态 当数据库处于挂起状态时,数据库所有的物理文件(控制文件、数据文件和重做日志文件)的I/O操作都被暂停,这样能够保证数据库在没有任何I/O操作的情况下进行物理备份。挂起状态与静默状态的区别是:挂起状态并不禁止非管理员用户进行数据库操作,只是暂时停止所有用户的I/O操作。24挂起数据库SQL
18、alter system suspend;恢复正常SQL alter system resume;查询状态SQLselect database_status from v$instance;25第第4章章 SQL*PLUS命令命令在数据库系统中,可以使用两种方式执行命令,一种方式是通过图形化工具,另一种方式是直接使用各种命令。图形化工具的特点是直观、简单、容易记忆,而直接使用命令则需要记忆具体命令的语法形式。但是,图形工具灵活性比较差,不利于用户对命令和其选项的理解;而命令则非常灵活,有利于加深用户对复杂命令选项的理解,并且可以完成某些图形工具无法完成的任务。在Oracle 11g系统中,提供
19、了用于执行SQL语句和PL/SQL程序的工具SQL*Plus。26本章知识要点:本章知识要点:理解SQL*Plus的运行环境进行基本的运行环境设置使用HELP命令DESCRIBE命令的作用PROMPT命令的使用SPOOL命令的使用使用COLUMN命令格式化查询结果缓存区命令的使用在SQL*Plus中运行脚本文件。274.1 SQL*PLUS的运行环境的运行环境 SQL*Plus运行环境是SQL*Plus的运行方式,查询语句执行结果显示方式的总称。设置合适的SQL*Plus运行环境,使得SQL*Plus能够按照用户的要求运行和执行各种操作。4.1.1 使用使用SET语句选项语句选项 在Oracl
20、e 11g系统中,用户可以使用SET命令来设置SQL*Plus的运行环境。28选项说明SET ARRAYSIZE 15|N设置SQL*PLUS一次从数据库中取出的行数,其取值范围为任意正整整数。set autocommiton|off|immediate|n该参数的值决定Oracle何时提交对数据库所做的修改。当设置为ON和IMMEDIATE时,当SQL命令执行完毕后,立即提交用户做的更改;而当设置为OFF时,则必须用户使用COMMIT命令提交。关于事务处理的请参考相关章节。set autoprinton|off自动打印变量值,如果autoprint设置为on,则在过程的执行过程中可以看到屏幕
21、上打印的变量值;设置为OFF时表示只显示“过程执行完毕”这样的提示。set autorecoveryon|off设定为on时,将以默认的文件名来记录重做记录,当需要恢复时,可以使用recover automatic database语句恢复,否则只能使用recover database语句恢复。Set autotraceon|off|trace onlyexplainstatistics对正常执行完毕的sql dml语句自动生成报表信息。set blockterminator c|on|off定义表示结束PL/SQL块结束的字符。set cmdsep;|c|on|off定义sql*Plus的命
22、令行区分字符,默认值为off,也就是说回车键表示下一条命令并开始执行;假如设置为on,则命令行区分字符会被自动设定成“;”,这样就可以在一行内用“;”分隔多条sql命令。set colsep _|text设置列和列之间的分隔字符。默认情况下,在执行select输出的结果中,列和列之间是以空格分隔的。这个分隔符可以通过使用SET COLSEP命令来定义。set linesize 80|n设置SQL*Plus在一行中能够显示的总字符数,默认值为80。可以的取值为任意正整数。set long 80|n为LONG型数值设置最大显示宽度,默认值为80。set newpage 1|n|none设置每页打印
23、标题前的空行数,默认值为1。set null text设置当SELECT语句返回NULL值时显示的字符串。set numformat format设置数字的默认显示格式。set pagesize 14|n设置每页打印的行数,该值包括NEWPAGE设置的空行数。set pauseoff|on|text设置SQL*Plus输出结果时是否滚动显示。当取值为NO时表示输出结果的每一页都暂停,用户按下回车键后继续显示;取为字符串时,每次暂停都将显示该字符串。set recsep wrapped|each|off显示或打印记录分隔符。其取值为WRAPPED时,只有在折叠的行后面打印记录分隔符;取值为EAC
24、H则表示每行之后都打印记录分隔符;OFF表示不必打印分隔符。set space1|n设置输出结果中列与列之间的空格数,默认值为10。set sqlcasemixed|lower|upper设置在执行SQL命令之前是否转换大小。取值可以为MIXED(不进行转换)、LOWER(转换为小写)和UPPER(转换为大写)。set sqlcontinue|test设置SQL*Plus的命令提示符。set time off|on控制当前时间的显示。取值为ON时,表示在每个命令提示符前显示当前系统时间;取值为OFF则不显示系统当前时间。set timing off|on控制是否统计每个SQL命令的运行时间。取
25、值为ON表示为统计,OFF则不统计。set underline-|c|on|off设置SQL*Plus是否在列标题下面添加分隔线,取值为ON或OFF时分别表示为打开或关闭该功能;还可以设置列标题下面分隔张的样式。set wrap on|off设置当一个数据项比当前行宽长时,SQL*Plus是否截断数据项的显示。取值为OFF时表示截断,ON表示为超出部分折叠到下一行显示。4.1.2 设置运行环境示例设置运行环境示例 在本节将通过几个示例介绍如何设置运行环境,以及设置后的效果。这些设置都是在平常操作中使用频率较高的运行环境。观看演示29304.2 SQL*PLUS命令命令 在Oracle 11g系
26、统中,SQL*Plus提供了许多可以定制该工具行为的命令。这些命令包括:HELP、DESCRIBE、PROMPT、SPOOL和SHWO等。314.2.1 HELP命令命令 SQL*Plus有许多命令,而且每个命令都有大量的选项,要记住每一个命令的所有选项是很困难的。不过SQL*Plus提供了内建的帮助系统,用户可以在需要的时候,随时可以使用HELP命令查询相关的命令信息。但是SQL*Plus的内建帮助只是提供了部分命令信息,SQL*Plus帮助系统可以向用户提供下面一些信息:命令标题。命令作用描述的文件。命令的缩写形式。命令中使用的强制参数和可选参数。4.2.2 DESCRIBE命令命令 在S
27、QL*Plus的许多命令中,用户使用最频繁的命令可能是DESCRIBE命令。DESCRIBE命令可以返回数据库中所存储的对象的描述。对于表、视图等对象而言,DESCRIBE命令都可以列出其各个列的名称以及各个列的属性。除此之外,DESCRIBE还会输出过程、函数和程序包的规范。Sqldesc scott.emp324.2.3 PROMPT命令命令 使用PROMPT命令可以在屏幕上输出一行数据,这种输出方式非常有助于在存储的脚本文件中向用户传递相应的信息。PROMPT命令的语法形式如下:33prompt prompt_text;sql prompt 显示当前用户及默认的表空间4.2.4 SPOO
28、L命令命令 使用SPOOL命令可以把查询结果保存到文件中,或者把查询结果发送到打印机中。SPOOL命令的语法格式如下:34spool file_name create|replace|append|off;SqlSpool f:output_file.txt4.3 格式化查询结果格式化查询结果 SQL*Plus提供了大量的命令用于格式化查询结果,使用这些命令可以对查询结果进行格式化,以产生用户需要的报表。使用这些命令可以实现重新设置列的标题,重新定义列的值的显示格式和显示宽度,为报表增加头标题和底标题,在报表中显示当前日期和页号,也可以为报表添加新的统计数据等。常用的格式化查询结果命令包括:C
29、OLUMN、COMPUTE、BREAK、BTITLE和TTITLE等。观看视频354.3.1 COLUMN命令命令 通过使用COLUMN命令,可以对控制查询结果集中列的显示格式。COLUMN命令的语法格式如下:36column column_name alias|option 4.3.2 TTITLE和和BTITLE命令命令 SQL*Plus的显示结果通常包括一个头部标题、列标题、查询结果和一个底部标题。如果输出结果需要打印多个页,则每个页都可以拥有自己的页标题和列标题。每页可以打印的数量由用户设置的页的大小决定,用户设置系统参数NEWPAGE可以决定头部标题之前的空行数;PAGESIZE参数则规定每页打印的行数;而每行可打印的字符数则由LINESIZE参数决定。374.4 缓存区缓存区 SQL*Plus可以在缓存区中存储用户最近执行的从命令。通过在缓存区中存储这些命令,用户可以重新调用、编辑或运行那些最近输入的SQL语句。编辑缓存区最常用的方法是将缓存区中的内容传递到Windows记事本中进行编辑。38