Oracle 9i学习日志(8)--创建数据库

一、优化的弹性架构:
Oracle推荐的标准数据库架构框架;
主要包括三条规则:建立一个统一的目录结构,可以容纳各种需求的数据库文件;将不同行为的对象放入不同的表空间;将不同的数据库组件放在不同的磁盘将大大提高数据库的可靠性和性能。
二、认证模型:
Oracle 9i学习日志(8)--创建数据库_第1张图片
操作系统认证:
属于dba组或oper组(对于Unix系统)的用户,即可用os认证方式。
password file认证:
在REMOTE_LOGIN_PASSWORDFILE=shared或none状态时,相当于 REMOTE_LOGIN_PASSWORDFILE=EXCLUSIVE但无password文件。 REMOTE_LOGIN_PASSWORDFILE是静态参数在重启instance前不能改变参数值。
在密码文件丢失的情况下可以做如下工作:
1、确认 REMOTE_LOGIN_PASSWORDFILE=EXCLUSIVE
2、创建新密码文件:$orapwd file=orapwSID password=password entries=max_users    #等号两端不要有空格
3、$ sqlplus /nolog
SQL> conn sys as sysdba
Enter password:( 任意输入)
Connected to an idle instance.
4、启动数据库到mount或open状态
SELECT USERNAME FROM V$PWFILE_USERS WHERE USERNAME != 'SYS' AND SYSDBA='TRUE';      #查看被授予sysdba权限的用户
SQL> REVOKE SYSDBA FROM SYS-user;
SQL> GRANT SYSDBA TO SYS-user;       
#将其重新加入密码文件,对有sysoper权限的用户执行类似操作。
 
注意:beginning with Oracle Database 11g Release 1, database passwords are case sensitive. (You can disable case sensitivity and return to pre�CRelease 11g behavior by setting the SEC_CASE_SENSITIVE_LOGON initialization parameter to FALSE.)
Connecting with Administrative Privileges: Example
This example illustrates that a user is assigned another schema (SYS) when connecting
with the SYSDBA system privilege. Assume that the sample user oe has been granted
the SYSDBA system privilege and has issued the following statements:
CONNECT oe
CREATE TABLE admin_test(name VARCHAR2(20));
Later, user oe issues these statements:
CONNECT oe AS SYSDBA
SELECT * FROM admin_test;
User oe now receives the following error:
ORA-00942: table or view does not exist
Having connected as SYSDBA, user oe now references the SYS schema, but the table
was created in the oe schema.
 
三、用dbca创建数据库:
1、设置环境变量
ORACLE_BASE
• ORACLE_HOME
• ORACLE_SID
ORA_NLS33      #与字符集相关参数的环境变量
PATH
LD_LIBRARY_PATH
2、$dbca
心得:数据库可以创建多个,启动不同的instance是根据环境变量里的ORACLE_SID来启动对应的instance。用远程客户端连接时也应设置好sid参数,以区分连接的instance。
四、手工创建数据库:
Step 1: Specify an Instance Identifier (SID) 
#数据库名字长度<=8,sid长度<=12,而数据库名字通常和sid相同,所以在sid的名字最好不要超过8个字符。
Step 2: Ensure That the Required Environment Variables Are Set
export ORACLE_BASE=/u01
export ORACLE_HOME=$ORACLE_BASE/oracle
export ORACLE_SID=test
export ORACLE_NLS33=$ORACLE_HOME/ocommon/nls/admin/data
export PATH=$ORACLE_HOME/bin:$PATH
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:$LD_LIBRARY_PATH
Step 3: Choose a Database Administrator Authentication Method
不管哪种认证方式都应该创建password文件。
Step 4: Create the Initialization Parameter File
Step 5: (Windows Only) Create an Instance
Step 6: Connect to the Instance
Step 7: Create a Server Parameter File
SQL> create spfile from pfile; #如果不创建spfile,则pfile里必须制定control files的参数值,而如果是spfile则这些值将会自动写入spfile。
Step 8: Start the Instance
SQL> startup nomount;
Step 9: Issue the CREATE DATABASE Statement
事先写好的sql脚本:
spool dbcreate.log;
create database "test"
        maxdatafiles 500
        maxinstances 8
        maxlogfiles 32
        character set "utf8"
        national character set al16utf16
        archivelog
        datafile
                '/u01/oradata/test/system01.dbf' size 300M
        extent management local
        default temporary tablespace temp tempfile '/u01/oradata/test/tempts01.dbf’ size 100M extent management local
        undo tablespace "undotbs1"
        datafile '/u01/oradata/test/undotbs01.dbf' size 200M
        logfile
    group 1 (
        '/u01/oradata/test/redo01a.rdo',
        '/u01/oradata/test/redo01b.rdo'
    ) size 100M,
    group 2 (
        '/u01/oradata/test/redo02a.rdo',
        '/u01/oradata/test/redo02b.rdo'
    ) size 100M,
    group 3 (
        '/u01/oradata/test/redo03a.rdo',
        '/u01/oradata/test/redo03b.rdo'
    ) size 100M
;
spool off;
注意:脚本中的有些参数要和初始化文件中的一致,执行脚本前需确认所需的目录是否创建,如:/u01/oradata/test/archive, /u01/admin/test/bdump  cdump  create  pfile  udump等初始化参数文件中指定的目录。缺省口令,sys:change_on_install;system:manager。
问题:新创建的数据库如果使用缺省口令,远程客户端能连接上来吗?
Step 10: Create Additional Tablespaces
可选,但通常要做,如:
CREATE TABLESPACE apps_tbs LOGGING DATAFILE '/u01/app/oracle/oradata/mynewdb/apps01.dbf' SIZE 500M REUSE AUTOEXTEND ON NEXT 1280K MAXSIZE UNLIMITED EXTENT MANAGEMENT LOCAL;
Step 11: Run Scripts to Build Data Dictionary Views
执行脚本:
spool log1.log
@?/rdbms/admin/catalog.sql   #"?"号代表ORACLE_HOME
@?/rdbms/admin/catproc.sql
@?/sqlplus/admin/pupbld.sql
 
Step 12: Run Scripts to Install Additional Options (Optional)
Step 13: Back Up the Database.
Step 14: (Optional) Enable Automatic Instance Startup
注意:如果在创建数据库的过程中出错而停止,则应将已创建好的文件删除后再重新创建。
本文出自 “ 冰冷的太阳” 博客,请务必保留此出处 http://luotaoyang.blog.51cto.com/545649/283652

你可能感兴趣的:(oracle,职场,oracle学习,休闲,Oracle日志)