Oracle管理Oracle中用sql语句创建数据库.docx
《Oracle管理Oracle中用sql语句创建数据库.docx》由会员分享,可在线阅读,更多相关《Oracle管理Oracle中用sql语句创建数据库.docx(12页珍藏版)》请在冰豆网上搜索。
Oracle管理Oracle中用sql语句创建数据库
(Oracle管理)Oracle中用sql语句创建数据库
二、在Windows下创建数据库
Oracle实例在Windows下表现为操作系统服务。
在windows下,使用命令行方式创建数据的方法有所不同,差别在于在Windows下,需要先创建数据库服务和实例。
1.确定数据库名、数据库实例名和服务名并创建目录(DBCA创建的脚本不包含建立目录命令,须自己创建)
建立目录命令(下面以db_name=eygle为例):
mkdirD:
\oracle\ora90\cfgtoollogs\dbca\eygle
mkdirD:
\oracle\ora90\database
mkdird:
\oracle\admin\eygle\adump
mkdird:
\oracle\admin\eygle\bdump
mkdird:
\oracle\admin\eygle\cdump
mkdird:
\oracle\admin\eygle\dpdump
mkdird:
\oracle\admin\eygle\pfile
mkdird:
\oracle\admin\eygle\udump
mkdird:
\oracle\flash_recovery_area
mkdird:
\oracle\oradata
mkdird:
\oracle\oradata\eygle
2.创建参数文件
在Windows下的参数文件名称及路径如下:
d:
\oracle\product\10.1.0\admin\DB_NAME\pfile\init.ora(oracle10g)
d:
\orant\database\iniORACLE_SID.ora(oracle7,oracle8)
参数据文件内容与前述一致。
这里不再说明。
3.选择数据库实例
设置环境变量ORACLE_SID
c:
\>setORACLE_SID=数据库实例名
4.创建数据库实例
在Windows中创建数据库实例的命令为Oradim.exe,是一个可执行文件,可以在操作系统符号下直接运行。
直接输入oradim显示此命令的帮助。
c:
\>Oradim
下面对Oradim命令的参数进行一个说明
-------------------------------
-NEW表示新建一个实例
-EDIT表示修改一个实例
-DELETE表示删除一个实例
-SIDsid指定要启动的实例名称
-SRVCservice指定要启动的服务名称
-INTPWDpassword以Internal方式连接数据库时的口令字
-MAXUSERScount该实例可以连接的最大用户数
-USRPWDpassword指定内部用户的口令,如是作为Windows管理登录,不用此参数
-PFILEpfile该实例所使用的参数文件名及路径
-STARTTYPEsrvc|inst|srvc,inst启动选项(srvc:
只启动服务,inst:
启动实例,服务必须先启动,srvc,inst:
服务和实例同时启动)
-SHUTTYPEsrvc|linst|srvc,inst关闭选项(srvc:
只关闭服务,实例必须已关闭,inst:
只关闭实例,srvc,inst:
服务和实例同时关闭)
-STARTMODEa|m创建实例所使用的模式(a:
自动,即windows启动时自动启动m:
手动)
-SHUTMODEa|i|m关闭实例时所使用的模式(a:
abort异常方式,i:
immediate立即方式,n:
normal正常方式)
----------------------------
例:
创建一个数据库实例
c:
\>oradim-NEW-SIDmyoracle-STARTMODEm-PFILE"d:
\fangys\initmyoracle.ora"
或
c:
\>oradim-NEW-SRVCOracleServicemyoracle-STARTMODEm-PFILE"d:
\fangys\initmyoracle.ora"
例:
修改一个数据实例
c:
\>oradim-EDIT-SIDmyoracle-STARTMODEa
或
c:
\>oradim-EDIT-SRVCOracleServicemyoracle-STARTMODEa
例:
删除一个实例
c:
\>oradim-DELETE-SIDmyoracle
或
c:
\>oradim-DELETE-SRVCOracleservicemyoracle
例:
启动服务与实例
c:
\>oradim-STARTUP-SIDmyoracle-STARTTYPEsrvc,inst
只启动服务
c:
\>oradim-STARTUP-SIDmyoracle-STARTTYPEsrvc
启动实例:
c:
\>oradim-STARTUP-SIDmyoracle-STARTTYPEinst
例:
关闭服务与实例
c:
\>oradim-SHUTDOWN-SIDmyoracle
c:
\>oradim-SHUTDOWN-SIDmyoracle-SHUTTYPEsrvc,inst
5.启动实例并创建数据库
c:
\>oradim-NEW-SIDmyoracle-INTPWDsyspass-STARTMODEa-PFILEd:
\fangys\initmyoracle.ora
c:
\>setORACLE_SID=myoracle
c:
\>sqlplussys/syspassassysdba
sql>startup-pfile=d:
\fangys\initmyoracle.oranomount
sql>CREATEDATABASEmyoracle
logfilegroup...
...
6.创建数据字典
sql>@d:
\oracle\product\10.1.0\db_1\rdbms\admin\catalog.sql;
sql>@d:
\oracle\product\10.1.0\db_1\rdbms\admin\catproc.sql;
sql>@d:
\oracle\product\10.1.0\db_1\rdbms\admin\catrep.sql;
sql>@d:
\oracle\product\10.1.0\db_1\javavm\install\initjvm.sql;
sql>@d:
\oracle\product\10.1.0\db_1\sqlplus\admin\ppbld.sql;
一、启动数据
$sqlplus"sys/passassysdba"
sql>startup
二、启动监听器
数据库启动后,如果未启动监听进程,则客户端无法与数据库连接。
监听进程的启动方法为:
$lsnrctlstart
在widnows中,可以从服务列表中启动监听器。
监听里程配置文件为listener.ora,位于目录/home/app/oracle/product/10.1.0/db1/network/admin/。
此配置文件分为两部分,一部分为监听程序本身的配置,包括协议,地址,端口号等;另一部分为监听程序所连接的数据库的实例信息,包括:
实例名,全局数据库名,oracle主目录等。
监听器可以利用oraclenetconfig向导来配置。
要显示监听器的运行状态:
$lsnrctlstatus;
要停止监听器:
$lsnrctlstop。
三、数据库的启动过程
分为三个阶段:
1.启动实例,包括以下操作:
1)读取参数文件
2)分配SGA
3)启动后台进程
2.装载数据库
装载数据库是将数据库与已启动的实例相联系。
数据库装载后,数据库保持关闭状态。
3.打开数据库
此步骤使用数据库可以进行正常的操作的处理。
主要是打开控制文件,数据库文件和日志文件。
四、数据库启动参数
1.NOMOUNT:
只启动实例,不装载数据库
sql>startupnomount
2.MOUNT:
启动实例,并装载数据,但不打开数据库
sql>startupmount
3.READONLY:
将数据库置为只读
sql>startupmount
sql>alterdatabaseopenreadonly
4.READWRITE:
以可读写方式打开数据,这是默认方式
sql>startupmount
sql>alterdatabaseopenreadwrite
5.OPEN:
打开数据库,这是默认方式
sql>startupmount
sql>alterdatabaseopen;
6.RESTRICT:
以受限方式打开,只有具有RESTRICTEDSESSION权限的用户才可以连接数据库
sql>startuprestrict
7.PFILE:
启时指定参数文件
sql>startuppfile=/u02/user/mypfile.ora
8.FORCE:
以强制方式启动数据库
sql>startuppfile=/u02/user/mypfile.oraopenrestrictforce
五、数据库的关闭
与启动过程相对应,关闭包括三个过程
1).关闭数据库
2).卸载数据库
3).关闭数据库实例
1.NORMAL关闭方式
NORMAL关闭方式是正常关闭方式,是默认关闭方式。
在这种关机方式下,数据库服务器必须等待所有客户端从Oracle中正常退出时,才可以关闭数据库。
SQL>SHUTDOWNNORMAL
2.IMMEDIATE关闭方式
使用这种方式关闭数据库时,系统将连接到数据库的所有用户尚未提交的事务全部回退,中断连接,然后关闭数据库。
SQL>SHUTDOWNIMMEDIATE
3.ABORT关闭方式
ABORT关闭方式为异常方式,使用这种方式关闭数据库时,系统立即将数据库实例关闭,对事务膛数据完整性不作检查。
是最快的关机方式。
sql>shutdownabort;
4.TRANSACTIONAL关闭方式
在这种关机方式中,数据库必须等待所有的客户运行的事务结束,提交或回退。
sql>shutdowntransactional
Oracle数据库的连接结构有三种:
1)组合用户与服务器结构:
在这种连接方式中,客户端与服务器同处一台机器中,对于每一个用户,其库应用程序与服务器程序组合成单个服务器进程。
2)专用服务器(DedicatedServer)结构:
在这种方式中,对于每一个用户,其数据库应用是由用户进程所运行,并有一个专用服务器进程为之服务,执行Oracle服务器代码。
3)多线程服务器(MultithreadedServer)体系结构:
在这种方式中,一个或多个客户应用程序共享一组服务器进程,与专用服务器不同的是,客户和服务器进程不是一对一的关系,而是由调度进程对多个服务器进程进行调度,以服务来自客户应用的连接请求。
专用服务器
专用服务器的工作过程:
1)客户端通过oraclenet向监听器发连接请求
2)监听器收到请求并将此请求导向服务器,服务器向用户返回一个连接成功信息,并为此用户创建一个专用服务器进程
3)客户直接与该专用服务器进程进行交互,处理SQL,并且服务器在该会话的PGA中建立一个专用SQL区。
如果客户端要求建立专用服务器连接方式,可以修改客户羰的网络配置文件tnsnames.ora或修改连接描述串。
增加关键字“Server=DEDICATED”,如:
prod=
(DESCRIPTION=
(ADDRESSLIST=
(ADDRESS=
(PROTOCOL=TCP)(HOST=192.168.0.3)(PORT=1521)
(SERVER=DEDICATED)
)
)
(CONNECT_DATA=(SID=PROD)
)
)
还必须修改SQLNET.ORA文件,增加“USE_DEDICATED_SERVER=TRUE”
多线程服务器体系结构
专用服务器结构中,一个服务器进程只为一个客户服务。
这样的话,如果有一千个客户,就需要有一千个对应的服务器进程,就会耗费大量的系统资源。
为了支持对于可伸缩性的需求,在oracle7中引入了多线程服务器(MTS,也称为共享服务器)。
下面说明共享服务器建立连接的过程,以级与建立专用服务器连接过程的不同:
1)客户通过网络与监听器联系
2)监听器检测到请求,基于Oraclenet结构来确定是否与多线程服务器连接。
监听器将客户请求导向相应的调度程序。
3)监听器通过使客户与调度程序了解对方的网络地址,从面完成了双方的介绍。
4)一旦客户与调度程序知道如何找到对方,它们就直接通信,不要需要监听器。
客户直接将操作请求发送给高度程序。
5)调度程序将客户请求放在SGA的请求队列中。
6)下一个可用的共享服务器进程从请求队列中读取请求,进行相应的工作。
7)共享服务器进程将结果存放在提交相应请求的调度程序的响应队列中。
8)调度程序从响应队列中读取数据并将结果送组客户。
有几个概念在这里作个补充说明:
1)监听器(Listener):
为一个或多个实例“监听”连接请求,它是oracle客户与服务器的中介。
监听器不是Oracle实例的一部分,它的作用是将连接的请求导向相应的实例。
2)调度程序(dispatcher):
在MTS体系结构中,监听器与调度程序联系,调度程序负责调度MTS中的各个共享服务器进程。
多线程服务器的设置参数有:
MTS_SERVICE:
多线程服务器名称,一般为数据库名
MTS_DISPATCHERS:
初始调度器个数
MTS_MAX_DISPATCHERS:
调度器最大个数
MTS_SERVERS:
共享服务器个数
MTS_MAX_SERVERS:
最大共享服务器个数
多线程服务器的设置是通过对以上各个参数的设置完成的。
格式如下:
MTS_SERVICE=RS
MTS_SERVERS=10
MTS_MAX_SERVERS=100
MTS_DISPATCHERS="(PROTOCOL=TCP)(POOL=YES)(MULT=YES)"
MTS_DISPATCHERS="(PROTOCOL=IPX)(POOL=YES)(MULT=YES)"
MTS_DISPATCHERS="(PROTOCOL=IPC)(POOL=YES)(MULT=YES)"
MTS_MAX_DISPATCHERS=100
有关多线程服务器的数据字典如下:
V$MTS
V$DISPATCHER
V$SHARED_SERVER
V$CIRCULT
各字典的详细说明请参考Oracle文档。
第八篇再述oracle数据库体系结构之四:
Oracle实例的进程结构
这里所讲的里程是指Unix系统中的进程,在Windows中,Oracle是一个操作系统服务。
Oracle实例由内存区域和后台进程组成。
Oracle实例分为单进程实例(一个进程执行全部的Oracle代码,只允许单个用户存取)和多进程实例(由多个进程执行Oracle代码的不同部分,对于每一个连接的用户都有一个进程,允许多个用户同时使用)。
在多进程结构中,除服务器进程(请注意,此“服务器进程”不是指所有的实例中的进程,见下面的说明)外,还有其他后台进程,包括:
Dnnn,DBWR,LGWR,ARCH,PMON,SMON,CKPT,RECO等。
在数据库启动后,这些进程常驻操作系统。
Oracle中所有进程的数量之和不能超过参数PROCESS设定的值:
sql>showparameterprocess
当Oracle客户端应用程序与Oracle实例连接的时候,Oracle会产生一个服务器进程来为这些客户服务,此进程在widnows下表现为线程。
此进程的主要作用有:
对于用户发出的SQL语句进行语法分析,编译,执行用户的SQL语句,如是数据块不在数据缓冲区时,则从磁盘数据文件将数据读入到SGA的共享数据缓冲区中,将SQL语句的执行结果返回组应用程序。
下面的语句用来查询数据库中的用户会话信息。
sql>selectsubstr(s.sid,1,3)sid,substr(s.serial#,1,5)ser,spid,substr(schemaname,1,10)schema,substr(type,1,3)typ,substr(decode((consistent_gets+block_gets),0,'None',(100*(consistent_gets+block_gets-physical_reads)/consistent_gets+block_gets))),1,4)"%hit",valuecpu,substr(block_changes,1,5)bchngfromv$processp,v$sesstatt,v$sess_ioi,v$sessionswherei.sid=s.sidandp.addr=paddr(+)ands.sid=t.sidandt.statistic#=12;
结果中:
sid表示会话ID号,
ser表示会话serial#号,serial#与sid组合以唯一表示一个会话,
spid表示操作系统进程号,
schema表示数据库用户名,
typ表示进程类型,use为用户进程,bac为后台进程
%hit表示数据缓冲区命中率,
cpu表示使用cpu的时间,
bchng表示修改了的数据块的个数。
下面介绍各个后台进程。
1.DBWR进程
DBWR(DatabaseWriter)进程将缓冲区中的数据写入数据文件,负责数据缓冲区的管理。
当数据缓冲区中的一个数据被修改后,被标记为“脏”,DBWR进程负责将“脏”数据写入磁盘。
DBWR采用LRU算法来替换数据缓冲区中的数据。
DBWR的作用包括:
1)管理数据缓冲区,以便服务器进程总能找到空闲缓冲区
2)将所有修改后的缓冲区中的数据写入数据库文件
3)使用LRU算法将最近使用过的块保留在内存中
4)通过延迟写来优化磁盘i/o.
在下列情况下DBWR要将脏数据写入磁盘数据文件:
1)当一个服务器进程将缓冲数据块移“脏表”,面该脏表达到一定程度进。
(该临界长度由参数DB_BLOCK_WRITE_BATCH决定)
2)当一个服务器进程在LRU表中查找DB_BLOCK_MAX_SCAN_CNT缓冲区时,没有查到空闲的缓冲区
3)出现超时
4)检查点发生时
在一个Oracle实例中,允许启动多个DBWR进程,DBWR进程个数由参数DB_WRITE_PROCESSES指定,上限为20,进程名依次自动命名为:
DBW0,DBW1,DBW2...DBW19。
sql>showparameterprocesses
2.LGWR进程
LGWR(LogWriter)进程将日志数据从日志缓冲区中写入磁盘日志文件中。
关于LGWR进程的工作时机可以看我写的第一篇《一次事务过程》。
LGWR的写盘条件是:
1)发生提交,即commit;
2)日志缓冲区达到总数的1/3时;
3)超时;
4)DBWR进程需要为检验点清除缓冲区时。
每一个Oracle实例只有一个LGWR进程。
LGWR将日志信息同步的写入到日志文件组的多个日志成员中,如果组中的一个成员文件被删除或不可使用,LGWR将日志信息继续写到该组的其他文件中,不影响数据库的运行。
3.SMON进程
SMON(SystemMonitor),系统监控进程,在实例启动时执行实例恢复,并负责清理不再使用的临时段。
4.PMON进程
PMON(ProcessMonitor),进程监控里程,在服务器进程出现故障时执行进程恢复,负责清理内存内存和释放该进程所使用的资源。
5.ARCH进程
ARCH(ArchiveProcess,归档进程)在日志存满时将日志信息写到磁盘或磁带,用于介质失败时的恢复。
日志信息首先产生于日志缓冲区,再由日志写入进程LGWR将日志数据写入日志文件组,日志切换时,由归档进程ARCH将日志数据从日志文件组中写入归档日志中。
在一个数据库实例中,归档进程最多可以启动10个,进程名依次自动命名为ARC0,ARC1,ARC2...ARC9,设置方法是:
在参数文件中增加参数LOG_ARCHIVE_MAX_PROCESSES。
关于如何启用数据库的自动归档,在前面的《物理结构》一篇中已有说明,这里说明一个几个相关的参数:
1)LOG_ARCHIVE_DEST:
用于设置归档日志的文件存储目录
2)LOG_ARCHIVE_DUBLEX_DEST:
用于设置归档日志文件的镜像存储目录,此参数在oracle8及以上的版本中支持
3)LOG_ARCHIVE_DEST_n:
用于设置更多的镜像目录,其中,1ALTERSYSTEMSETLOG_ARCHIVE_DEST_STATE_1=DEFER;
此参数只适用于oracle10g及以上版本。
6.CKPT进程
CKPT(CheckPoint,检查点)进程出现时,系统对全部数据库文件及控制文件的文件头的同步号进行修改,以保证数据库的同步。
以下两个参数是对CKPT有影响的:
LOG_CHECKPOINT_TIMEOUT:
决定产生一个检验点的时间间隔,单位为秋,默认为1800;
LOG_CHECKPOINT_INTERVAL:
执行一个检验点需要填充的日志文件块的数目,默认为0,表示不起作用。
系统对于数据库的改变信息用系统改变号SCN表示,SCN也叫检验点号,在日志中用CHECKPOINT_CHANGE#表示,它是数据文件,日志文件,控制文件的同步的同步依据,同时存储在这三个中,在系统改变时,检验点号也会同时改变。
引起CKPT产生的主要时机有:
1)日志切换时
2)达到LOG_CHECKPOINT_TIMEOUT指定的间隔时间
3)达到LOG_CHECKPOINT_INTERVAL指定的日志块数
4)数据库关闭
5)DBA强制产生
6)表空间OFFLINE时
7.RECO进程
RECO(Recover,恢复)进程用于分布式数据库系统,RECO进程自动地解决在分布式数据库中的事务故障。
8.LCKn进程
LCKn(锁进程)用于Oracle并行服务器环境下,用于多个实例间的封锁,该进程最多可以启动10个。
9.Dnnn进程
Dnnn(Despatcher,调度)进程。
用于多线程服务器体系结构中。
详见下一篇《Oracle连接配置结构》
10.SNP进程
SNP是作业进程,主要用于分布式数据库中,进行数据库之间快照的自动刷新,并同时通达DBMS_JOB程序包自动运行预定的存储过程,SQL,PL/sql程序等。
有两个参数用来控制作业进程的计划:
1)JOB_QUEUE_PROCESS:
用于设置作业进程个数
2)JOB_QUEUE_INTERVAL:
用于设置作业进程被周期性唤醒的时间间隔
后台进程跟踪信息
所有修改数据库结构的命令会自动被后台进程跟踪记录,跟踪信息由oracle后台进程自动存储,跟踪文件的名称为alter_SID。
此文件的存储目录由参数BACKGROUND)DUMP_DEST指定。
可以用工具命令TKPROF来格式化跟踪文件,如:
$tkproforalogfile1.log
除了跟踪后台进程外,还可以启用参数SQL_TRACE对用户的语句进行跟踪。
修改参数文件:
TIMED_STATISTICS=TRUE
USER_DUMP_DEST=目录名
MAX_DUMP_FILE_SIZE=5M
SQL_TRACE=TRUE
或者:
SQL>ALTERSESSIONSETSQL_TRACE=TRUE对当前会话进行SQL跟踪。
锁等待问题与KILLS