ORACLE学习经验(一)-- 建立本地ORACLE数据库

一. 安装ORACLE服务端

  1. 下载ORACLE
    建议直接从ORACLE官网选择适合版本下载。
    WINDOWS x64 ORACLE 11g:
    https://www.oracle.com/technetwork/database/enterprise-edition/downloads/112010-win64soft-094461.html
  2. 配置环境变量
    安装完ORACLE之后需要配置一下环境变量(需要管理员权限)
    我的电脑-属性-高级系统设置-环境变量
    变量:ORACLE_HOME
    值:E:\xxx\xxx\product\11.2.0\dbhome_1(ORACLE安装目录)
    变量:TNS_ADMIN
    值:E:\xxx\xxx\product\11.2.0\dbhome_1\ADMIN\NETWORK
    (或者写成:%ORACLE_HOME%\ADMIN\NETWORK)

二. 创建数据库

  1. Database Configuration Assistant
    ORACLE自带的数据库创建工具
    在这里插入图片描述
    在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述
    此处设置DBA账户的口令
    在这里插入图片描述
    一直下一步直到安装完成。
    //
    期间遇到过的报错:
    ORA-12638身份证明检索失败。
    ----解决方法:ADMIN/NETWORK/sqlnet.ora 文件中的授权方式从NTS改成NONE,这样会导致之后登录数据库时报错:ORA-01031 权限不足,此时改回NTS即可。
    在这里插入图片描述

三. 建立监听

建立监听我们主要配置LISTENER.ORA和TNSNAMES.ORA两个文件
LISTENER.ORA:
1.修改SID_LIST_LISTENER下的SID_NAME为刚建立的本地数据库实例名
2.添加本地数据库的LISTENER,HOST = localhost
注:当处于某些局域网时,HOST处填写localhost会导致host名错误,局域网内用户无法链接,出现此问题时填写完整的主机名即可。

// LISTENER.ORA
SID_LIST_LISTENER =
  (SID_LIST =
    (SID_DESC =
      (SID_NAME = KDB)
      (ORACLE_HOME = E:\xxx\product\11.2.0\dbhome_1)
      (PROGRAM = extproc)
      (ENVS = "EXTPROC_DLLS=ONLY:E:\xxx\product\11.2.0\dbhome_1\bin\oraclr11.dll")
    )
  )


LISTENER_KDB =
  (DESCRIPTION_LIST =
    (DESCRIPTION =
      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
      (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))
    )
  )

TNSNAMES.ORA:
1.添加本地数据库的要素
2.添加本地数据库的LISTENER(与LISTENER.ORA中名称一致)

// TNSNAMES.ORA
KDB =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SID = KDB)
    )
  )
LISTENER_KDB =
 (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))

当监听程序设置完成后,在后台使用lsnrctl start调起监听。

监听程序的常用命令:
lsnrctl start
lsnrctl stop
lsnrctl reload
lsnrctl status
每次修改LISTENER.ORA后需要用reload命令重启一次
//
监听程序设置时遇到的报错:
ORA-12514TNS:listener does not currently … requested in connect descriptor
解决方法:LISTENER.ORA与TNSNAMES.ORA文件中配置的LISTENER不一致,修改至一致即可
ORA-12505TNS: 监听程序当前无法识别连接描述符中所给出的SID
解决方法:LISTENER.ORA中的SID_NAME修改成本地数据库的实例名

四. 数据库调起

1.操作系统验证登入

命令行键入: sqlplus /nolog
命令行键入: conn / as sysdba

C:\Users\xxx>sqlplus /nolog

SQL*Plus: Release 11.2.0.1.0 Production on 星期三 65 16:45:31 2019

Copyright (c) 1982, 2010, Oracle.  All rights reserved.

SQL> conn / as sysdba
已连接到空闲例程。
2.数据库打开与关闭

数据库启动命令:startup

SQL> startup
ORACLE 例程已经启动。

Total System Global Area  805875712 bytes
Fixed Size                  2180064 bytes
Variable Size             482348064 bytes
Database Buffers          314572800 bytes
Redo Buffers                6774784 bytes
数据库装载完毕。
数据库已经打开。

数据库卸载命令:shutdown immediate

SQL> shutdown immediate
数据库已经关闭。
已经卸载数据库。
ORACLE 例程已经关闭。
SQL>

当数据库处于卸载状态或非正常关闭时,会报以下错误:
ORA-01034 - Oracle not available
ORA-27101 - shared memory realm does not exist
解决方法:使用上述操作系统认证方法启动或重新启动数据库
//
当监听程序处于关闭状态或监听文件配置错误时,会报以下错误:
ORA-00119 - invalid specification for system parameter
ORA-00132 - syntax error or unresolved network name ‘LISTENER_ORCL’
解决方法:命令行键入lsnrctl start启动监听

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值