Oracle中用sql语句创建数据库

上传人:jin****ng 文档编号:111269506 上传时间:2022-06-20 格式:DOC 页数:10 大小:150KB
收藏 版权申诉 举报 下载
Oracle中用sql语句创建数据库_第1页
第1页 / 共10页
Oracle中用sql语句创建数据库_第2页
第2页 / 共10页
Oracle中用sql语句创建数据库_第3页
第3页 / 共10页
资源描述:

《Oracle中用sql语句创建数据库》由会员分享,可在线阅读,更多相关《Oracle中用sql语句创建数据库(10页珍藏版)》请在装配图网上搜索。

1、二、在Windows下创建数据库Oracle实例在Windows下表现为操作系统服务。在windows下,使用命令行方式创建数据 的方法有所不同,差别在于在Windows下,需要先创建数据库服务和实例。1. 确定数据库名、数据库实例名和服务名并创建目录(DBCA创建的脚本不包含建立目录命 令,须自己创建)建立目录命令(下面以db_name二eygle为例):mkdir D:oracleora90cfgtoollogsdbcaeyglemkdir D:oracleora90databasemkdir d:oracleadmineygleadumpmkdir d:oracleadmineygleb

2、dumpmkdir d:oracleadmineyglecdumpmkdir d:oracleadmineygledpdumpmkdir d:oracleadmineyglepfilemkdir d:oracleadmineygleudumpmkdir d:oracleflash_recovery_areamkdir d:oracleoradatamkdir d:oracleoradataeygle2. 创建参数文件在Windows下的参数文件名称及路径如下:d:oracleproduct10.1.0adminDB_NAMEpfileinit.ora(oraclelOg) d:orantdat

3、abaseiniORACLE_SID.ora(oracle7,oracle8)参数据文件内容与前述一致。这里不再说明。3. 选择数据库实例设置环境变量ORACLE_SIDc:se t 0只人仇_3口=数据库实例名4. 创建数据库实例在Windows中创建数据库实例的命令为Oradim.exe,是一个可执行文件,可以在操作系统 符号下直接运行。直接输入oradim显示此命令的帮助。c:0radim下面对Oradim命令的参数进行一个说明 -NEW表示新建一个实例-EDIT表示修改一个实例-DELETE表示删除一个实例-SID sid指定要启动的实例名称-SRVC service指定要启动的服务名

4、称-INTPWD password以Internal方式连接数据库时的口令字-MAXUSERS count该实例可以连接的最大用户数-USRPWD password指定内部用户的口令,如是作为Windows管理登录,不用此参数 -PFILE pfile该实例所使用的参数文件名及路径-STARTTYPE srvc|inst|srvc,inst启动选项(srvc:只启动服务,inst:启动实例,服务必 须先启动,srvc,inst:服务和实例同时启动)-SHUTTYPE srvc|linst|srvc,inst关闭选项(srvc:只关闭服务,实例必须已关闭,inst: 只关闭实例,srvc,ins

5、t:服务和实例同时关闭)-STARTMODE a|m创建实例所使用的模式(a:自动,即windows启动时自动启动m:手动) -SHUTMODE a|i|m关闭实例时所使用的模式(a:abort异常方式,i:immediate立即方 式,n:normal正常方式) 例:创建一个数据库实例c:oradim -NEW -SID myoracle -STARTMODE m -PFILE d:fangysinitmyoracle.ora 或c:oradim -NEW -SRVC OracleServicemyoracle -STARTMODE m -PFILE d:fangysi nit myorac

6、le.ora例:修改一个数据实例c:oradim -EDIT -SID myoracle -STARTMODE a 或c:oradim -EDIT -SRVC OracleServicemyoracle -STARTMODE a例:删除一个实例c:oradim -DELETE -SID myoracle 或c:oradim -DELETE -SRVC OracleServicemyoracle例:启动服务与实例c:oradim -STARTUP -SID myoracle -STARTTYPE srvc,inst 只启动服务c:oradim -STARTUP -SID myoracle -ST

7、ARTTYPE srvc启动实例:c:oradim -STARTUP -SID myoracle -STARTTYPE inst例:关闭服务与实例c:oradim -SHUTDOWN -SID myoraclec:oradim -SHUTDOWN -SID myoracle -SHUTTYPE srvc,inst5. 启动实例并创建数据库c:oradim -NEW -SID myoracle -INTPWD syspass -STARTMODE a -PFILE d:fangysinitmyoracle.orac:set ORACLE_SID二myoraclec:sqlplus sys/sys

8、pass as sysdbasqlstartup -pfile二d:fangysinitmyoracle.ora nomountsqlCREATE DATABASE myoraclelogfile group.6. 创建数据字典sqld:oracleproduct10.1.0db_lrdbmsadmincatalog.sql;sqld:oracleproduct10.1.0db_lrdbmsadmincatproc.sql;sqld:oracleproduct10.1.0db_lrdbmsadmincatrep.sql;sqld:oracleproduct10.1.0db_ljavavmins

9、tallinitjvm.sql;sqld:oracleproduct10.1.0db_lsqlplusadminppbld.sql;一、启动数据$sqlplus sys/pass as sysdbasqlstartup二、启动监听器数据库启动后,如果未启动监听进程,则客户端无法与数据库连接。监听进程的启动方 法为:$lsnrctl start在widnows中,可以从服务列表中启动监听器。监听里程配置文件为 lis tener.ora , 位于目录 /home/app/oracle/product/10.1.0/dbl/network/admin/。此配置文件分为两部分,一部分为监听程序本身的

10、配置,包括协议,地址,端口号等;另- 部分为监听程序所连接的数据库的实例信息,包括:实例名,全局数据库名,oracle主目 录等。监听器可以利用oracle net config向导来配置。要显示监听器的运行状态:$lsnrc tl stat us;要停止监听器:$lsnrctl stop。三、数据库的启动过程分为三个阶段:1. 启动实例,包括以下操作:1)读取参数文件2)分配SGA3)启动后台进程2. 装载数据库装载数据库是将数据库与已启动的实例相联系。数据库装载后,数据库保持关闭状态。3打开数据库此步骤使用数据库可以进行正常的操作的处理。主要是打开控制文件,数据库文件和日 志文件。四、数据

11、库启动参数1. N0M0UNT :只启动实例,不装载数据库sqlstartup nomount2. MOUNT :启动实例,并装载数据,但不打开数据库sqlstartup mount3. READ ONLY:将数据库置为只读sqlstartup mountsqlalter database open read only4. READ WRITE :以可读写方式打开数据,这是默认方式sqlstartup mountsqlalter database open read write5.OPEN :打开数据库,这是默认方式sqlstartup mountsqlalter database open;

12、6. RESTRICT:以受限方式打开,只有具有RESTRICTED SESSION权限的用户才可以连接数据库 sqlstartup restrict7. PFILE :启时指定参数文件sqlstartup pfile二/u02/user/mypfile.ora& FORCE:以强制方式启动数据库sqlstartup pfile=/u02/user/mypfile.ora open restrict force五、数据库的关闭与启动过程相对应,关闭包括三个过程1) .关闭数据库2) .卸载数据库3) .关闭数据库实例1. NORMAL关闭方式NORMAL关闭方式是正常关闭方式,是默认关闭方式。

13、在这种关机方式下,数据库服务 器必须等待所有客户端从Oracle中正常退出时,才可以关闭数据库。SQLSHUTDOWN NORMAL2. IMMEDIATE关闭方式使用这种方式关闭数据库时,系统将连接到数据库的所有用户尚未提交的事务全部回 退,中断连接,然后关闭数据库。SQLSHUTDOWN IMMEDIATE3. ABORT关闭方式ABORT关闭方式为异常方式,使用这种方式关闭数据库时,系统立即将数据库实例关闭, 对事务膛数据完整性不作检查。是最快的关机方式。sqlshutdown abort;4. TRANSACTIONAL 关闭方式在这种关机方式中,数据库必须等待所有的客户运行的事务结束

14、,提交或回退。sqlshutdown transactionalOracle数据库的连接结构有三种:1) 组合用户与服务器结构:在这种连接方式中,客户端与服务器同处一台机器中,对于每 一个用户,其库应用程序与服务器程序组合成单个服务器进程。2) 专用服务器(Dedicated Server)结构:在这种方式中,对于每一个用户,其数据库应用 是由用户进程所运行,并有一个专用服务器进程为之服务,执行Oracle服务器代码。3) 多线程服务器(Multithreaded Server)体系结构:在这种方式中,一个或多个客户应用 程序共享一组服务器进程,与专用服务器不同的是,客户和服务器进程不是一对一

15、的关系, 而是由调度进程对多个服务器进程进行调度,以服务来自客户应用的连接请求。专用服务器Dedicated Server ProcessClientAIntranet专用服务器的工作过程:1) 客户端通过oracle net向监听器发连接请求2) 监听器收到请求并将此请求导向服务器,服务器向用户返回一个连接成功信息,并为此 用户创建一个专用服务器进程3) 客户直接与该专用服务器进程进行交互,处理SQL,并且服务器在该会话的PGA中建 立一个专用SQL区。如果客户端要求建立专用服务器连接方式,可以修改客户羰的网络配置文件tnsnames.ora 或修改连接描述串。增加关键字“Server=DE

16、DICATED”,如:prod二(DESCRIPTION=(ADDRESSLIST=(ADDRESS= (PROTOCOL=TCP)(HOST=192.168.O.3)(PORT=1521)(SERVER=DEDICATED)(CONNECT_DATA=(SID=PROD)还必须修改 SQLNET.ORA 文件,增加“USE_DEDICATED_SERVER=TRUE”多线程服务器体系结构Shared Sen/er Process专用服务器结构中,一个服务器进程只为一个客户服务。这样的话,如果有一千个客户, 就需要有一千个对应的服务器进程,就会耗费大量的系统资源。为了支持对于可伸缩性的需 求,

17、在oracle7中引入了多线程服务器(MTS,也称为共享服务器)。下面说明共享服务器建立 连接的过程,以级与建立专用服务器连接过程的不同:1) 客户通过网络与监听器联系2) 监听器检测到请求,基于Oracle net结构来确定是否与多线程服务器连接。监听器将客 户请求导向相应的调度程序。3) 监听器通过使客户与调度程序了解对方的网络地址,从面完成了双方的介绍。4) 一旦客户与调度程序知道如何找到对方,它们就直接通信,不要需要监听器。客户直接 将操作请求发送给高度程序。5) 调度程序将客户请求放在SGA的请求队列中。6) 下一个可用的共享服务器进程从请求队列中读取请求,进行相应的工作。7) 共享

18、服务器进程将结果存放在提交相应请求的调度程序的响应队列中。8) 调度程序从响应队列中读取数据并将结果送组客户。有几个概念在这里作个补充说明:1) 监听器(Listener):为一个或多个实例“监听”连接请求,它是oracle客户与服务器的中 介。监听器不是Oracle实例的一部分,它的作用是将连接的请求导向相应的实例。2) 调度程序(dispatcher):在MTS体系结构中,监听器与调度程序联系,调度程序负责调度 MTS中的各个共享服务器进程。多线程服务器的设置参数有:MTS_SERVICE:多线程服务器名称,一般为数据库名 MTS_DISPATCHERS:初始调度器个数MTS_MAX_DI

19、SPATCHERS:调度器最大个数 MTS_SERVERS:共享服务器个数MTS_MAX_SERVERS:最大共享服务器个数 多线程服务器的设置是通过对以上各个参数的设置完成的。格式如下:MTS_SERVICE=RS MTS_SERVERS=10MTS_MAX_SERVERS=1OO 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_M

20、AX_DISPATCHERS=1OO有关多线程服务器的数据字典如下:V$MTS V$DISPATCHER V$SHARED_SERVERV$CIRCULT 各字典的详细说明请参考Oracle文档。第八篇 再述oracle数据库体系结构之四:0racle实例的进程结构这里所讲的里程是指Unix系统中的进程,在Windows中,Oracle是一个操作系统服务。Oracle实例由内存区域和后台进程组成。Oracle实例分为单进程实例(一个进程执行全部的Oracle代码,只允许单个用户存取) 和多进程实例(由多个进程执行Oracle代码的不同部分,对于每一个连接的用户都有一个进 程,允许多个用户同时使

21、用)。在多进程结构中,除服务器进程(请注意,此“服务器进程”不是指所有的实例中的进程, 见下面的说明)外,还有其他后台进程,包括:Dnnn,DBWR, LGWR,ARCH,PMON,SMON,CKPT,RECO 等。在数据库启动后,这些进程常驻操作系统。Oracle中所有进程的数量之和不能超过参 数PROCESS设定的值:sqlshow parameter process当Oracle客户端应用程序与Oracle实例连接的时候,Oracle会产生一个服务器进程 来为这些客户服务,此进程在widnows下表现为线程。此进程的主要作用有:对于用户发出 的SQL语句进行语法分析,编译,执行用户的SQ

22、L语句,如是数据块不在数据缓冲区时,则 从磁盘数据文件将数据读入到SGA的共享数据缓冲区中,将SQL语句的执行结果返回组应 用程序。下面的语句用来查询数据库中的用户会话信息。sqlselec tsubs tr (s.sid,l,3)sid,subs tr (s.serial#,l,5)ser,spid,subs tr (schemaname,l,10)schema,subs tr(ty pe,l,3)typ,substr(decode(consistent_gets+block_gets),0,None,(100*(consistent_gets+b lock_gets-physical_re

23、ads)/consistent_gets+block_gets),l,4)%hit, valuecpu,substr(block_changes,l,5) bchng from v$process p,v$sesstat t, v$sess_io i,v$session s where i.sid二s.sid and p.addr=paddr(+) and s.sid 二t .sid and t.statistic#=12;结果中:sid表示会话ID号,ser 表示会话serial#号,serial#与sid组合以唯一表示一个会话,spid表示操作系统进程号,schema表示数据库用户名,ty

24、p表示进程类型,use为用户进程,bac为后台进程%hit表示数据缓冲区命中率,cpu表示使用cpu的时间,bchng表示修改了的数据块的个数。下面介绍各个后台进程。1. DBWR进程DBWR(Da tabase Wri ter)进程将缓冲区中的数据写入数据文件,负责数据缓冲区的管理。 当数据缓冲区中的一个数据被修改后,被标记为脏”,DBWR进程负责将“脏”数据写入磁盘。 DBWR采用LRU算法来替换数据缓冲区中的数据。DBWR的作用包括:1) 管理数据缓冲区,以便服务器进程总能找到空闲缓冲区2) 将所有修改后的缓冲区中的数据写入数据库文件3) 使用LRU算法将最近使用过的块保留在内存中4)

25、通过延迟写来优化磁盘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。sqlshow parameter proce

26、sses2. LGWR进程LGWR (Log Writer)进程将日志数据从日志缓冲区中写入磁盘日志文件中。关于LGWR进程的工作时机可以看我写的第一篇一次事务过程LGWR的写盘条件是:1)发生提交,即commit;2)日志缓冲区达到总数的1/3时;3)超时;4)DBWR进程需要为检验点清除缓冲区时。 每一个Oracle实例只有一个LGWR进程。LGWR将日志信息同步的写入到日志文件组的多个日志成员中,如果组中的一个成员文件被 删除或不可使用,LGWR将日志信息继续写到该组的其他文件中,不影响数据库的运行。3. SMON进程SMON(SystemMonitor),系统监控进程,在实例启动时执行

27、实例恢复,并负责清理不再 使用的临时段。4. PMON进程PMON(ProcessMoni tor),进程监控里程,在服务器进程出现故障时执行进程恢复,负责 清理内存内存和释放该进程所使用的资源。5. ARCH进程ARCH(Archive Process,归档进程)在日志存满时将日志信息写到磁盘或磁带,用于介质 失败时的恢复。日志信息首先产生于日志缓冲区,再由日志写入进程LGWR将日志数据写入日志文件组, 日志切换时,由归档进程ARCH将日志数据从日志文件组中写入归档日志中。在一个数据库实例中,归档进程最多可以启动10个,进程名依次自动命名为ARCO,ARC1,ARC2.ARC9,设置方法是:

28、在参数文件中增加参数 LOG_ARCHIVE_MAX_PROCESSES。关于如何启用数据库的自动归档,在前面的物理结构一 篇中已有说明,这里说明一个几个相关的参数:1)LOG_ARCHIVE_DEST:用于设置归档日志的文件存储目录2)LOG_ARCHIVE_DUBLEX_DEST:用于设置归档日志文件的镜像存储目录,此参数在oracle 8 及以上的版本中支持3)LOG_ARCHIVE_DEST_n:用于设置更多 的镜像 目录,其中,1 ALTER SYSTEM SET LOG_ARCHIVE_DEST_STATE_1=DEFER;此参数只适用于oracle 10g及以上版本。6. CKP

29、T进程CKPT(CheckPoint,检查点)进程出现时,系统对全部数据库文件及控制文件的文件头 的同步号进行修改,以保证数据库的同步。以下两个参数是对CKPT有影响的:LOG_CHECKPOINT_TIMEOUT:决定产生一个检验点的时间间隔,单位为秋,默认为1800; LOG_CHECKPOINT_INTERVAL:执行一个检验点需要填充的日志文件块的数目,默认为0,表示 不起作用。系统对于数据库的改变信息用系统改变号SCN表示,SCN也叫检验点号,在日志中用 CHECKPOINT_CHANGE#表示,它是数据文件,日志文件,控制文件的同步的同步依据,同时存 储在这三个中,在系统改变时,检

30、验点号也会同时改变。引起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,调度)进程。用于多线程服务器体系结构中。详见下

31、一篇Oracle 连接配置结构10. SNP进程SNP是作业进程,主要用于分布式数据库中,进行数据库之间快照的自动刷新,并同时 通达DBMS_JOB程序包自动运行预定的存储过程,SQL,PL/sql程序等。有两个参数用来控制 作业进程的计划:1)JOB_QUEUE_PROCESS:用于设置作业进程个数2)JOB_QUEUE_INTERVAL:用于设置作业进程被周期性唤醒的时间间隔 后台进程跟踪信息所有修改数据库结构的命令会自动被后台进程跟踪记录,跟踪信息由oracle后台进程 自动存储,跟踪文件的名称为alter_SID。此文件的存储目录由参数BACKGROUND)DUMP_DEST 指定。可

32、以用工具命令TKPROF来格式化跟踪文件,如:$tkprof oralogfile1.log除了跟踪后台进程外,还可以启用参数SQL_TRACE对用户的语句进行跟踪。修改参数文 件:TIMED_STATISTICS=TRUE USER_DUMP_DEST=目录名MAX_DUMP_FILE_SIZE=5MSQL_TRACE=TRUE或者:SQLALTER SESSION SET SQL_TRACE=TRUE对当前会话进行 SQL 跟踪。 锁等待问题与KILL SESSION为了保证数据的一致性,系统提供锁机制。有关锁的概念可以参数数据库系统概论 一书。要了解当前在等待锁资源的用户:sqlselec t a.username,a.sid,a,serial#,b.id1 from v$session,v$lock where a.lockwa it二 b.kaddr;要了解锁住其它用户的用户进程:SQLSELECT A.USERNAME,A.SID,A,SERIAL#,B.ID1 FROM V$SESSION A,V$LOCK B WHERE B.ID1 IN (SELECT DISTINCT E.ID1 FROM V$SESSION D,V$LOCK E WHERE D.LOCKWAIT=E.KADDR) AND A.SID=B.SID AND B.REQUEST=O;

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!