Docker中安装Oracle10g和oracle增删改查

Docker中安装Oracle 10g

一、Docker中安装Oracle 10安装步骤

Docker中安装Oracle 10g

1.下载镜像

docker pull registry.cn-shanghai.aliyuncs.com/techerwang/oracle:ora10g_10205

2.重新tag镜像

docker tag registry.cn-shanghai.aliyuncs.com/techerwang/oracle:ora10g_10205 oracle10g:10205

3.起动docker容器

docker run -itd --name oracle10205 -h jemora10g -p 31521:1521 --privileged=true --restart=always oracle10g:10205 init

4.进入容器

docker exec -it oracle10205 bash

5.起动监听和数据库

root@localhost \~# docker exec -it oracle10205 bash

root@jemora10g /# su - oracle

-bash: iexport: command not found

oracle@jemora10g \~$ lsnrctl start

oracle@jemora10g \~$ sql

SYS@jem10g> startup

6.创建用户并赋予权限

SQL> create user root identified by "123456";

SQL> grant connect,resource,dba to root; --表示把 connect,resource,dba权限授予root用户

7.配置数据库开机启动

容器内修改配置

root@jemora10g /# vim /etc/rc.d/rc.local

增加下面两行

su - oracle -c "lsnrctl start"

su - oracle -c "dbstart"

修改配置root@jemora10g /# vim /etc/oratab

将最后一个参数修改为Y

JEM10G:/u01/app/oracle/product/10.2.0.1/dbhome_1:Y

二、连接数据库登录

端口31521

服务名jem10g

默认账号密码:root/123456

#查看日志等待安装完成

docker logs -f 容器id

三 oracle数据库的增删改查及联表查询的相关操作

oracle数据库,创建students数据表,创建100万条数据

--创建students数据表,创建1000条数据

create table OUTLN.Students as

select rownum as id,

to_char(sysdate + rownum/24/3600, 'yyyy-mm-dd hh24:mi:ss') as inc_datetime,

CONCAT('zhang',rownum) as studen_name,

CONCAT('183',trunc(dbms_random.value(00000000, 99999999))) as stu_number,

trunc(dbms_random.value(0, 100)) as stu_age,

dbms_random.string('x', 20) random_string

from dual

connect by level <= 1000000;

增删改查

-- 查询表

select * FROM OUTLN.students WHERE ID<10;

select * from students where ID=(select max(id) from students);

-- SQL 语句查询 Oracle 数据库中的所有库

SELECT tablespace_name FROM dba_tablespaces;

-- SQL 语句查询某个数据库中的所有表

SELECT table_name FROM user_tables;

-- 查询Oracle 12C实例名

SELECT instance_name FROM v$instance;

-- 查询Oracle中所有的用户

SELECT * FROM dba_users;

-- 修改数据

update students set id=999 where ID=2;

-- 插入语句

insert into OUTLN.students(ID,INC_DATETIME) values(99999,'2022-06-01 19:57:44');

-- 删除数据

delete from students where id=999;

drop table OUTLN.students;

-- 删除表

drop table myTestTable;

-- 删除库

drop database test1;

相关推荐
Patrick_Wilson3 天前
从「改个端口」到 502:Next.js on k8s 的容器端口、Service 映射与 env 覆盖
docker·kubernetes·next.js
Suroy3 天前
DockerView-Go:用 Go 写一个终端 Docker 监控工具,顺便做了个 Web 仪表盘
docker
云恒要逆袭3 天前
运行你的第一个Docker容器
后端·docker·容器
ClouGence4 天前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
宋均浩4 天前
# Docker 镜像瘦身实战:从 1.2G 到 80MB 的五个优化步骤
ci/cd·docker
程序员老赵5 天前
10 分钟部署 OpenCode:Docker 一键安装,浏览器打开就能用 AI 写代码(附完整命令与排错)
docker·容器·ai编程
WangMingHua1115 天前
LM Studio Docker 部署——本地大模型一键启动
docker
曲幽6 天前
别再用网页翻译看源码了!你的私人翻译神器LibreTranslate,部署避坑指南来了
python·docker·web·pot·translate·libretranslate·arogstranslate
武子康8 天前
调查研究-183 Apple container:Mac 上用轻量 VM 跑 Linux 容器,Swift 会改写本地容器体验吗?
docker·容器·apple
ClouGence10 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle