Oracle的安装以及一些相关问题

系列文章目录

Oracle的安装以及一些相关问题


文章目录


前言

一段时间没更新,主要最近一直在找工作,最终还是顺着春招找到工作了,现在已经入职一周了,以后可能会开个专栏记录一些工作中的bug。

因为公司使用oracle数据库,所以这周搞了不少oracle的东西,现在记录一下。


一、Oracle的安装

为了方便练习,我在本地用Docker装了一个Oracle用作学习。

我们搜索镜像,直接找下载量最高的。

直接下载比较慢且文件比较大,网络不好可以选择换源或者开个魔法。

bash 复制代码
docker pull iatebes/oracle_11g

之后创建容器并且进入修改配置。

bash 复制代码
docker run -d --name oracle11g -p 1521:1521 iatebes/oracle_11g
docker exec -it oracle11g  bash
# 修改root密码
passwd
# 切换oracle用户
su - oracle
# 匿名登录
sqlplus /nolog
# dba登录
conn /as sysdba
# 添加用户
alter user sys identified by sys;

之后就可以正常使用了,因为仅作练习环境,故不做持久化存储。

之后使用dbeaver进一下连接测试就可以了。

二、常用命令

bash 复制代码
# 启动oracle
startup
# 停止oracle
shutdown immediate;
# 强制停止
shutdown abort;
# 监听
lsnrctl start
lsnrctl stop
lsnrctl status

三、误删dbf

oracle依靠dbf存储,要删除数据,需要先删除表空间在删除底层的dbf数据文件,顺序不能错,如果先删除了dbf会导致表空间不可用也不可删除。

修复方法

bash 复制代码
# 关闭数据库
shutdown immediate
# 进入挂载模式
startup mount
# 删除dbf元数据
alter database datafile 'xxx.dbf' offline drop;
# 打开数据库
alter database open;
# 删除表空间
drop tablespace xxx including contents and datafiles;
# 重启oracle
shutdown immediate
startup

四、PLSQL乱码

这个是由于电脑环境和oracle环境字符集不匹配造成的。我们需要将数据库和环境统一。

查看数据库编码。

bash 复制代码
select * from V$NLS_PARAMETERS

公司用的是gbk系列的。

然后将设置新的环境变量

因为公司使用虚拟环境办公所以很多命令和截图没法展示。

五、oracle更换数据库字符集

bash 复制代码
# 登录
sqlplus / as sysdba
# 关闭数据库
shutdown immediate
# 进入mount
startup mount
# 设置session
ALTER SYSTEM ENABLE RESTRICTED SESSION;
ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0;
ALTER SYSTEM SET AQ_TM_PROCESSES=0;
# 打开数据库
alter database open;
# 修改字符集
ALTER DATABASE character set INTERNAL_USE xxx;
# 重启数据库
shutdown immediate
startup mount

总结

这次就写到这,我以往是按照章节来写博客,以后可能会相对更新多一些但更杂一些,看具体情况吧。

相关推荐
正在走向自律21 小时前
Java连接电科金仓数据库(KingbaseES)实战指南
java·数据库·oracle·国产数据库·kingbase
寻星探路21 小时前
数据库造神计划第五天---增删改查(CRUD)(1)
数据库
小虾米vivian21 小时前
达梦:将sql通过shell脚本的方式放在后台执行
服务器·数据库·sql
水无痕simon21 小时前
1. 数据库架构演变与分库分表介绍
数据库·数据库架构
专注代码七年1 天前
查询 mysql中 所有的 非空记录字段
数据库·mysql
a.3021 天前
OpenCV(cv2)学习笔记:从模板匹配入门到常用函数
数据库·ubuntu·ssh
大视码垛机1 天前
速度与安全双突破:大视码垛机重构工业自动化新范式
大数据·数据库·人工智能·机器人·自动化·制造
向上的车轮1 天前
如何用 Rust 重写 SQLite 数据库(二):是否有市场空间?
数据库·rust·sqlite
jc06201 天前
4.2-中间件之MySQL
数据库·mysql