系列文章目录
Oracle的安装以及一些相关问题
文章目录
- 系列文章目录
- 前言
- 一、Oracle的安装
- 二、常用命令
- 三、误删dbf
- 四、PLSQL乱码
- 五、oracle更换数据库字符集
- 总结
前言
一段时间没更新,主要最近一直在找工作,最终还是顺着春招找到工作了,现在已经入职一周了,以后可能会开个专栏记录一些工作中的bug。
因为公司使用oracle数据库,所以这周搞了不少oracle的东西,现在记录一下。
一、Oracle的安装
为了方便练习,我在本地用Docker装了一个Oracle用作学习。
我们搜索镜像,直接找下载量最高的。
直接下载比较慢且文件比较大,网络不好可以选择换源或者开个魔法。
docker pull iatebes/oracle_11g
之后创建容器并且进入修改配置。
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进一下连接测试就可以了。
二、常用命令
# 启动oracle
startup
# 停止oracle
shutdown immediate;
# 强制停止
shutdown abort;
# 监听
lsnrctl start
lsnrctl stop
lsnrctl status
三、误删dbf
oracle依靠dbf存储,要删除数据,需要先删除表空间在删除底层的dbf数据文件,顺序不能错,如果先删除了dbf会导致表空间不可用也不可删除。
修复方法
# 关闭数据库
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环境字符集不匹配造成的。我们需要将数据库和环境统一。
查看数据库编码。
select * from V$NLS_PARAMETERS
公司用的是gbk系列的。
然后将设置新的环境变量
因为公司使用虚拟环境办公所以很多命令和截图没法展示。
五、oracle更换数据库字符集
# 登录
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
总结
这次就写到这,我以往是按照章节来写博客,以后可能会相对更新多一些但更杂一些,看具体情况吧。