浅析新建Oracle数据库的三种方法

 更新时间:2013年08月01日 15:23:22   作者:  
以下是对新建Oracle数据库的三种方法进行了详细的分析介绍,需要的朋友可以过来参考下

1.通过运行Oracle Database Configuration  Assistant 创建、配置、或删除数据库(也可在命令行下输入dbca);
2.用命令行的方式建立数据库
3.通过运行自定义的批处理脚本(或create_ORACLE_SID.bat(create_ORACLE_SID.sql))来创建、配置、或删除数据库。

详述:
1.通过运行Oracle Database Configuration Assistant 创建、配置、或删除数据库;
建议不熟悉创建过程的DBA使用该方法,只需要根据选项“下一步”进行配置,最后生成数据库的创建脚本(建议保留),或者直接创建数据库;
优点:GUI方法使用方便;
缺点:不过创建过程有些慢;

2.用命令行的方式建立数据库

复制代码 代码如下:

CONNECT / AS SYSDBA
  STARTUP PFILE= 'C:oracleadmininit_testorcl.ora' NOMOUNT;
  CREATE DATABASE testOrcl DATAFILE '/u02/oracle/testOrcl/system01.dbf' SIZE 100M
  LOGFILE GROUP1 ('/u01/oracle/testOrcl/redo1a.log',
  '/u02/oracle/testOrcl/redo1b.log') SIZE 500K,
  GROUP2 ('/u01/oracle/testOrcl/redo1a.log',
  '/u02/oracle/testOrcl/redo1b.log') SIZE 500K
  CHARACTER SET ZHS16CGB231280;

--将数据库直接从未建置状态转换到打开状态
  ALTER DATABASE OPEN;

--删除数据库(Dropping a Database)
  SPOOL C:DROP_DATABASE.BAT
  SELECT 'DEL '||NAME 删除数据库相关数据文件 FROM V$DATAFILE;
  SELECT 'DEL '||MEMBER 删除数据重构日志文件 FROM V$LOGFILE;
  SPOOL OFF;


优点:可以熟悉创建指令,创建原理;
缺点:配置简单,要求熟记命令行指令;
 
3.通过运行自定义的批处理或SQL脚本(create_ORACLE_SID.bat或create_ORACLE_SID.sql)来创建
复制代码 代码如下:

--create_ORACLE_SID.bat
  set ORACLE_SID= ORACLE_SID.
del  C:ORACLE8IdatabasepwdORACLE_SID.ora
  C:ORACLE8Ibinoradim -new -sid ORACLE_SID. -intpwd oracle -startmode manual
  -pfile C:ORACLE8IadminORACLE_SIDpfileinit.ora
  C:ORACLE8Ibinsvrmgrl @C:WINNTProfilesAdministratorLbORACLE_SIDrun.sql
  C:ORACLE8Ibinsvrmgrl @C:WINNTProfilesAdministratorLbORACLE_SIDrun1.sql
  C:ORACLE8Ibinoradim -edit -sid ORACLE_SID -startmode auto

--ORACLE_SIDrun.sql
  spool C:ORACLE8IadminORACLE_SIDcreatecreatedb
  set echo on
  connect INTERNAL/oracle
  startup nomount pfile=C:ORACLE8IadminORACLE_SIDpfileinit.ora
  CREATE DATABASE ORACLE_SID
  LOGFILE 'C:ORACLE8IoradataORACLE_SIDredo01.log' SIZE 1024K,
  'C:ORACLE8IoradataORACLE_SIDredo02.log' SIZE 1024K
  MAXLOGFILES 32
  MAXLOGMEMBERS 2
  MAXLOGHISTORY 1
  DATAFILE 'C:ORACLE8IoradataORACLE_SIDsystem01.dbf' SIZE 50M REUSE
  MAXDATAFILES 254
  MAXINSTANCES 1
  CHARACTER SET ZHT16BIG5
  NATIONAL CHARACTER SET ZHT16BIG5;
  spool off

--ORACLE_SIDrun1.sql
  spool C:ORACLE8IadminORACLE_SIDcreatecreatedb1
  set echo on
  connect INTERNAL/oracle
ALTER DATABASE DATAFILE 'C:ORACLE8IoradataORACLE_SIDsystem01.dbf' AUTOEXTEND ON;
  CREATE ROLLBACK SEGMENT SYSROL TABLESPACE "SYSTEM" STORAGE (INITIAL  100K NEXT 100K);
  ALTER ROLLBACK SEGMENT "SYSROL" ONLINE;

Linux平台下Oracle的操作

下面对Oracle的操作都是在Linux平台下进行的!
1.su Oracle
2.sqlplus /logon
3.connect test/test assysdba(test/test是Oracle用户和密码)
4.startup
5.lsnrctl
首选启动数据库
su - Oracle
sqlplus /nolog
conn /as sysdba
startup
然后启动监听:
进入/opt/Oracle/product/9.2.0/bin/
lsnrctl start
运行shudown命令关闭数据库
[Oracle@wing /Oracle]$ sqlplus" / as sysdba" //以sysdba用户登陆数据库
SQL> shutdown

启动Oracle 9i 数据库
[Oracle@wing bin]$ sqlplus " /as sysdba"
SQL> startup

启动Oracle 9i监听程序
Oracle的监听程序主要是为客户端的连接提供接口
[Oracle@wing bin]$ lsnrctl
LSNRCTL> start

关闭Oracle 9i监听程序
[Oracle@wing bin]$ lsnrctl
LSNRCTL> stop

先看看Oracle_SID 环境变量设置是否正确。
9i:
$ sqlplus /nolog
SQL> connect / as sysdba
SQL> startup
$ lsnrctl start
8i:
$ svrmgrl
SVRMGR> connect internal
SVRMGR> startup
$ lsnrctl start
在哪里报错??
一般只要设置这2处就好了~
/etc/oratab
ora2:/Oracle/app/Oracle/product/8.1.7:Y 
/etc/inittab
oralce:2:wait:/bin/su - Oracle -c '/Oracle/app/Oracle/product/8.1.7/bin/lsnrctl start'
Oracle:2:wait:/bin/su - Oracle -c '/Oracle/app/Oracle/product/8.1.7/bin/dbstart'

启动步骤:
su - Oracle
[Oracle@websvr1 Oracle]$ sqlplus /nolog
SQL> connect / as sysdba
SQL> startup
SQL> quit
[Oracle@websvr1 Oracle]$ lsnrctl start
可用 [Oracle@websvr1 Oracle]$ lsnrctl status 查看监听是否已经启动

关闭步骤:
su - Oracle
[Oracle@websvr1 Oracle]$ lsnrctl stop
[Oracle@websvr1 Oracle]$ sqlplus /nolog
SQL> connect / as sysdba
SQL> shutdown immediate
SQL> quit

相关文章

  • oracle日期分组查询的完整实例

    oracle日期分组查询的完整实例

    这篇文章主要给大家介绍了关于oracle日期分组查询的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • Oracle中Like与Instr模糊查询性能大比拼

    Oracle中Like与Instr模糊查询性能大比拼

    本文通过实例代码给大家介绍了Oracle中Like与Instr模糊查询性能对比,需要的朋友参考下吧
    2017-05-05
  • Oracle在PL/SQL中使用子查询

    Oracle在PL/SQL中使用子查询

    这篇文章介绍了Oracle在PL/SQL中使用子查询的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • Oracle 用户权限管理方法

    Oracle 用户权限管理方法

    Oracle 用户权限管理方法,对于想要学习oracle安全的朋友,是个入门级的资料。
    2009-08-08
  • Oracle实例启动时报错:ORA-32004的解决方法

    Oracle实例启动时报错:ORA-32004的解决方法

    最近在启动实例时遇到了一些错误,通过查找的相关的资料终于解决,决定分享出来给有需要的朋友们,所以下面这篇文章主要给大家介绍了在Oracle实例启动时报错:ORA-32004的解决方法,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-10-10
  • [Oracle] 浅析令人抓狂的ORA-01555问题

    [Oracle] 浅析令人抓狂的ORA-01555问题

    首先要说明的一点是:ORA-01555错误是一个“安全”的错误,它不会造成数据丢失或损坏,只是会让接收到该错误的查询无法继续。以下就是对发生ORA-01555错误的原因进行了介绍,需要的朋友可以参考下
    2013-07-07
  • 支持在线写SQL的Oracle学习免费网站推荐!(个人常使用)

    支持在线写SQL的Oracle学习免费网站推荐!(个人常使用)

    为了便于在线练习,我们常常需要一个在线运行SQL的功能,下面这篇文章主要给大家推荐介绍了一个支持在线写SQL的Oracle学习免费网站(个人常使用),需要的朋友可以参考下
    2022-12-12
  • ip修改后orcale服务无法启动问题解决

    ip修改后orcale服务无法启动问题解决

    今天配置虚拟机中设计了下ip,使虚拟机和主机处在同一网段,然后使用webservice就成功了就来了,oracle连接不上了,接下来讲提供详细的解决方法
    2012-11-11
  • oracle中读写blob字段的问题解析

    oracle中读写blob字段的问题解析

    这篇文章以程序实例说明通过JDBC操纵Oracle数据库LOB类型字段的几种情况
    2013-09-09
  • 基于oracle expdp命令的使用详解

    基于oracle expdp命令的使用详解

    本篇文章是对oracle expdp命令的使用进行了详细的分析介绍,需要的朋友参考下
    2013-05-05

最新评论