oracle10G 数据库名实例名ORACLESID 及创建数据库.docx

上传人:b****2 文档编号:1707586 上传时间:2023-05-01 格式:DOCX 页数:22 大小:183.59KB
下载 相关 举报
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第1页
第1页 / 共22页
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第2页
第2页 / 共22页
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第3页
第3页 / 共22页
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第4页
第4页 / 共22页
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第5页
第5页 / 共22页
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第6页
第6页 / 共22页
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第7页
第7页 / 共22页
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第8页
第8页 / 共22页
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第9页
第9页 / 共22页
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第10页
第10页 / 共22页
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第11页
第11页 / 共22页
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第12页
第12页 / 共22页
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第13页
第13页 / 共22页
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第14页
第14页 / 共22页
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第15页
第15页 / 共22页
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第16页
第16页 / 共22页
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第17页
第17页 / 共22页
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第18页
第18页 / 共22页
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第19页
第19页 / 共22页
oracle10G 数据库名实例名ORACLESID 及创建数据库.docx_第20页
第20页 / 共22页
亲,该文档总共22页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

oracle10G 数据库名实例名ORACLESID 及创建数据库.docx

《oracle10G 数据库名实例名ORACLESID 及创建数据库.docx》由会员分享,可在线阅读,更多相关《oracle10G 数据库名实例名ORACLESID 及创建数据库.docx(22页珍藏版)》请在冰点文库上搜索。

oracle10G 数据库名实例名ORACLESID 及创建数据库.docx

oracle10G数据库名实例名ORACLESID及创建数据库

oracle10G 数据库名、实例名、ORACLE_SID 及创建数据库- hl3292转载修改

 

数据库名、实例名、数据库域名、全局数据库名、服务名,

这是几个令很多初学者容易混淆的概念。

相信很多初学者都与我一样被标题上这些个概念搞得一头雾水。

我们现在就来把它们弄个明白。

一、数据库名

什么是数据库名?

数据库名就是一个数据库的标识,就像人的身份证号一样。

他用参数DB_NAME表示,如果一台机器上装了多全数据库,那么每一个数据库都有一个数据库名。

在数据库安装或创建完成之后,参数DB_NAME被写入参数文件之中。

格式如下:

DB_NAME=myorcl

...

在创建数据库时就应考虑好数据库名,并且在创建完数据库之后,数据库名不宜修改,即使要修改也会很麻烦。

因为,数据库名还被写入控制文件中,控制文件是以二进制型式存储的,用户无法修改控制文件的内容。

假设用户修改了参数文件中的数据库名,即修改DB_NAME的值。

但是在Oracle启动时,由于参数文件中的DB_NAME与控制文件中的数据库名不一致,导致数据库启动失败,将返回ORA-01103错误。

数据库名的作用

数据库名是在安装数据库、创建新的数据库、创建数据库控制文件、修改数据结构、备份与恢复数据库时都需要使用到的。

有很多Oracle安装文件目录是与数据库名相关的,如:

winnt:

d:

\oracle\product\10.1.0\oradata\DB_NAME\...

Unix:

/home/app/oracle/product/10.1.0/oradata/DB_NAME/...

pfile:

winnt:

d:

\oracle\product\10.1.0\admin\DB_NAME\pfile\ini.ora

Unix:

/home/app/oracle/product/10.1.0/admin/DB_NAME/pfile/init$ORACLE_SID.ora

跟踪文件目录:

winnt:

/home/app/oracle/product/10.1.0/admin/DB_NAME/bdump/...

另外,在创建数据时,careatedatabase命令中的数据库名也要与参数文件中DB_NAME参数的值一致,否则将产生错误。

同样,修改数据库结构的语句alterdatabase,当然也要指出要修改的数据库的名称。

如果控制文件损坏或丢失,数据库将不能加载,这时要重新创建控制文件,方法是以nomount方式启动实例,然后以createcontrolfile命令创建控制文件,当然这个命令中也是指指DB_NAME。

还有在备份或恢复数据库时,都需要用到数据库名。

总之,数据库名很重要,要准确理解它的作用。

查询当前数据名

方法一:

selectnamefromv$database;

方法二:

showparameterdb

方法三:

查看参数文件。

修改数据库名

前面建议:

应在创建数据库时就确定好数据库名,数据库名不应作修改,因为修改数据库名是一件比较复杂的事情。

那么现在就来说明一下,如何在已创建数据之后,修改数据库名。

步骤如下:

1.关闭数据库。

2.修改数据库参数文件中的DB_NAME参数的值为新的数据库名。

3.以NOMOUNT方式启动实例,修建控制文件(有关创建控制文件的命令语法,请参考oracle文档)

二、数据库实例名

什么是数据库实例名?

数据库实例名是用于和操作系统进行联系的标识,就是说数据库和操作系统之间的交互用的是数据库实例名。

实例名也被写入参数文件中,该参数为instance_name,在winnt平台中,实例名同时也被写入注册表。

数据库名和实例名可以相同也可以不同。

在一般情况下,数据库名和实例名是一对一的关系,但如果在oracle并行服务器架构(即oracle实时应用集群)中,数据库名和实例名是一对多的关系。

这一点在第一篇中已有图例说明。

查询当前数据库实例名

方法一:

selectinstance_namefromv$instance;

方法二:

showparameterinstance

方法三:

在参数文件中查询。

数据库实例名与ORACLE_SID

虽然两者都表是oracle实例,但两者是有区别的。

instance_name是oracle数据库参数。

而ORACLE_SID是操作系统的环境变量。

ORACLD_SID用于与操作系统交互,也就是说,从操作系统的角度访问实例名,必须通过ORACLE_SID。

在winnt不台,ORACLE_SID还需存在于注册表中。

且ORACLE_SID必须与instance_name的值一致,否则,你将会收到一个错误,在unix平台,是“ORACLEnotavailable”,在winnt平台,是“TNS:

协议适配器错误”。

数据库实例名与网络连接

数据库实例名除了与操作系统交互外,还用于网络连接的oracle服务器标识。

当你配置oracle主机连接串的时候,就需要指定实例名。

当然8i以后版本的网络组件要求使用的是服务名SERVICE_NAME。

这个概念接下来说明。

三、数据库域名

什么是数据库域名?

在分布工数据库系统中,不同版本的数据库服务器之间,不论运行的操作系统是unix或是windows,各服务器之间都可以通过数据库链路进行远程复制,数据库域名主要用于oracle分布式环境中的复制。

举例说明如:

全国交通运政系统的分布式数据库,其中:

福建节点:

fj.jtyz

福建厦门节点:

xm.fj.jtyz

江西:

jx.jtyz

江西上饶:

sr.jx.jtyz

这就是数据库域名。

数据库域名在存在于参数文件中,他的参数是db_domain.

查询数据库域名

方法一:

selectvaluefromv$parameterwherename='db_domain';

方法二:

showparameterdomain

方法三:

在参数文件中查询。

全局数据库名

全局数据库名=数据库名+数据库域名,如前述福建节点的全局数据库名是:

oradb.fj.jtyz

四、数据库服务名(经常是orcl)

什么是数据库服务名?

从oracle9i版本开始,引入了一个新的参数,即数据库服务名。

参数名是SERVICE_NAME。

如果数据库有域名,则数据库服务名就是全局数据库名;否则,数据库服务名与数据库名相同。

查询数据库服务名

方法一:

selectvaluefromv$parameterwherename='service_name';

方法二:

showparameterservice_name

方法三:

在参数文件中查询。

数据库服务名与网络连接

从oracle8i开如的oracle网络组件,数据库与客户端的连接主机串使用数据库服务名。

之前用的是ORACLE_SID,即数据库实例名

创建Oracle数据库(以Oracle10g为例)

有两种创建数据库的方式,一种是以命令行脚本方式,即手动方式创建;另一种是利用Oracle提供的数据库配置向导来创建。

本篇主要介绍在Unix和Windows下以命令行脚本方式创建Oracle数据库。

一个完整的数据库系统,应包括一个物理结构、一个逻辑结构、一个内存结构和一个进程结构,如果要创建一个新的数据库,则这些结构都必须完整的建立起来。

一、在Unix下创建数据库

1.确定数据库名、数据库实例名和服务名

关于数据库名、数据库实例名和服务名,我之前有专门用一篇来详细介绍。

这里就不再说明了。

2.创建参数文件

参数文件很确定了数据库的总体结构。

Oracle10g有两种参数文件,一个是文本参数文件,一种是服务器参数文件。

在创建数据库时先创建文本参数文件,在数据库创建后,可以由文件参数文件创建服务器参数文件。

文本参数文件的取名方式为initORACLE_SID.ora,其中,ORACLE_SID是数据库实例名。

其名称及路径为:

/home/app/oracle/product/10.1.0/admin/DB_NAME/pfile/initORACLE_SID.ora

其中,DB_NAME为数据库名。

所以,应创建一个以之命名的目录,并将文本参数文件存放在上述目录中。

假设新创建的数据库名为MYORACLE,SID与数据库名一致。

则上述目录实际为:

/home/app/oracle/product/10.1.0/admin/MYORACLE/pfile/initMYORACLE.ora

1)参数文件的介绍

参数文件决定着数据库的总体结构,用于设置数据库的近260个系统参数。

下面分类别说明一下各参数的作用,关于参数的详细使用说明请参考Oracle官方参考文档。

a.数据库标识类参数

DB_NAME:

数据库名,此参数在创建数据前决定,数据库创建后修改时,必须建控制文件

DB_DOMAIN:

数据库域名,用于区别同名数据库。

数据库名与域名一起构成了全局数据库名

INSTANCE_NAME:

数据库实例名,可以与数据库相同

SERVICE_NAMES:

数据库服务名,与全局数据库名相同如果没有域名,则服务名就是数据库名

b.日志管理类参数

LOG_ARCHIVE_START:

是否启动自动归档进程ARCH

LOG_ARCHIVE_DEST:

归档日志文件存储目录

LOG_ARCHIVE_FORMAT:

归档日志文件的默认文件存储格式

LOG_ARCHIVE_DUPLEX_DEST:

归档日志文件镜像存储目录(Oracle8以上)

LOG_ARCHIVE_DEST_n:

归档日志文件存储目录(Oracle8i以上)

LOG_ARCHIVE_DEST_STATE_n:

设置参数LOG_ARCHIVE_DEST_n失效或生效

LOG_ARCHIVE_MAX_PROCESSES:

设置自动归档进程的个数

LOG_ARCHIVE_MIN_SUCCEED_DEST:

设置最少的成功归档日志存储目录的个数

LOG_CHECKPOINT_INTERVAL:

根据日志数量设置检验点频率

LOG_CHECKPOINT_TIMEOUT:

根据时间间隔设置检验点频率

c.内存管理参数

DB_BLOCK_SIZE:

标准数据块大小

DB_nK_CACHE_SIZE:

非标准数据块数据缓冲区大小

SHARED_POOL_SIZE:

共享池大小控制参数,单位为字节

DB_CACHE_SIZE:

标准数据块数据缓冲区大小

DB_BLOCK_BUFFERS:

数据缓冲区大小,9i之后已放弃使用

LOG_BUFFER:

日志缓冲区大小

SORT_AREA_SIZE:

排序区大小

LARGE_POOL_SIZE:

大池大小

JAVA_POOL_SIZE:

Java池大小

d.最大许可用户数量限制参数

LICENSE_MAX_SESSIONS:

数据库可以连接的最大会话数

LICENSE_MAX_USERS:

数据库支持的最大用户数

LICENSE_MAX_WARNING:

数据库最大警告会数(会话数据达到这个值时,产生新会话时就会产生警告信息)

e.系统跟踪信息管理参数

USER_DUMP_DEST:

用户跟踪文件生成的设置

BACKGROUND_DUMP_DEST:

后台进程跟踪文件生成的位置

MAX_DUMPFILE_SIZE:

跟踪文件的最大尺寸

f.系统性能优化与动态统计参数

SQL_TRACE:

设置SQL跟踪

TIMED_STATICS:

设置动态统计

AUDIT_TRAIL:

启动数据库审计功能

g.其他系统参数

CONTROL_FILES:

控制文件名及路径

Undo_MANAGMENT:

Undo空间管理方式

ROLLBACK_SEGMENTS:

为这个例程分配的回退段名

OPEN_CURSORS:

一个用户一次可以打开的游标的最大值

PROCESSES:

最大进程数,包括后台进程与服务器进程

IFILE:

另一个参数文件的名字

DB_RECOVERY_FILE_DEST:

自动数据库备份目录

DB_RECOVERY_FILE_SIZE:

数据库备份文件大小

2)参数文件样式

db_name=myoracle

instance_name=myoracle

db_domain=

service_names=

control_files=(/home/app/oracle/product/10.1.0/oradata/myoracle/control01.ctl,

/home/app/oracle/product/10.1.0/oradata/myoracle/control02.ctl,

/home/app/oracle/product/10.1.0/oradata/myoracle/control03.ctl)

db_block_size=8192

user_dump_dest=/home/app/oracle/product/10.1.0/admin/myoracle/udump

background_dump_dest=/home/app/oracle/product/10.1.0/admin/myoracle/bdump

core_dump_dest=/home/app/oracle/product/10.1.0/admin/myoracle/cdump

db_recovery_file_dest=/home/app/oracle/product/10.1.0/flash_recover_area

db_recovery_file_size=100G

...

3.设置操作系统参数

$ORACLE_SID=myoracle

$exportORACLE_SID

4.启动实例并创建数据库

在创建数据库之前,首先要以新的数据库参数启动数据库实例,因为这时数据库的控制文件还没有产生,不能MOUNT或OPEN数据库。

启动实例时,Oracle只按照内存参数分配SGA区,启动系统后台进程。

$sqlplus"sys/passassysdba"

sql>startupnomount

如果参数文件不在规定的目录中,可以在启动实例时指定参数文件:

sql>startuppfile=/export/home/user/initmyoracle.initnomount

在实例启动后就可以使用CREATEDATABASE命令创建数据。

其详细语法请参考Oracle官方SQL参考文档。

这里以实例来介绍:

sql>CREATEDATABASEmyoracle

MAXINSTANCE1

MAXLOGHISTORY216

MAXLOGFILES50

MAXLOGMEMBERS5

DATAFILE'/home1/app/oracle/product/10.1.0/oradata/myoracle/system01.dbf'SIZE500m

AUTOEXTENDONNEXT100mMAXSIZEUNLIMITED

LOGFILE

GROUP1('/home1/app/oracle/product/10.1.0/oradata/myoracle/log1a.log',

'/home1/app/oracle/product/10.1.0/oradata/myoracle/log1b.log')SIZE10m,

GROUP2('/home1/app/oracle/product/10.1.0/oradata/myoracle/log2a.log',

'/home1/app/oracle/product/10.1.0/oradata/myoracle/log2b.log')SIZE10m,

GROUP3('/home1/app/oracle/product/10.1.0/oradata/myoracle/log3a.log',

'/home1/app/oracle/product/10.1.0/oradata/myoracle/log3b.log')SIZE10m,

UndoTABLESPACEundotbsDATAFILE

'/home1/app/oracle/product/10.1.0/oradata/myoracle/undotbs01.dbf'size200m

AUTOEXTENDONNEXT100mMAXSIZEUNLIMITED

DEFAULTTEMPORARYTALESPACEtempTEMPFILE

'/home1/app/oracle/product/10.1.0/oradata/myoracle/temp01.dbf'size325m

AUTOEXTENDONNEXT100mMAXSIZEUNLIMITED

DEFAULTTABLESPACEusersDATAFILE

'/home1/app/oracle/product/10.1.0/oradata/myoracle/usertbs01.dbf'size1000m

CHARACTERSETZHS16GBK;

这里说明一下CREATEDATABASE语句的各个关键字的含义:

DATAFILE:

SYSTEM表空间的数据文件定义

LOGFILE:

日志文件组的定义

Undo_TABLESPACE:

重做表空间的定义

DEFAULTTEMPORTYTABLESPACE:

默认临时表空间的定义

DEFAULTTABLESPACE:

默认数据表空间的定义。

5.创建数据字典

在数据库创建结束后,数据库自动处于OPEN状态下,这时所有V$××××类数据字典都可以查询。

而其它数据字典,如DBA_DATA_FILES、DBA_TABLESPACES等都不存在,必须通过下列骤为系统创建数据字典。

1)加载常用的数据字典包

sql>@/home/app/oracle/product/10.1.0/db_1/rdbms/catalog

2)加载PL/SQL程序包

sql>@/home/app/oracle/product/10.1.0/db_1/rdbms/admin/catproc

3)加载数据复制支持软件包

sql>@/home/app/oracle/product/10.1.0/db_1/rdbms/admin/catrep

4)加载Java程序包

sql>@/home/app/oracle/product/10.1.0/db_1/javavm/install/initjvm

5)加载系统环境文件

sql>connectsystem/pass

sql>@/home/app/oracle/product/10.1.0/db_1/sqlplus/admin/pupbld

二、在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-SRVC

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 人文社科 > 法律资料

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2