oracle创建用户相关命令

Oracle CDB/PDB 用户管理分类总结

公共用户(CDB$ROOT)创建与管理

创建公共用户

CREATE USER C##FM_COPY IDENTIFIED BY "Tna@ssw0rd"

DEFAULT TABLESPACE FMTBS

CONTAINER=ALL;

全局授权(同步到所有PDB)

-- 授权 CONTAINER=ALL; -- 核心参数:全局授权,同步到所有PDB

GRANT DBA, CONNECT, RESOURCE, UNLIMITED TABLESPACE TO C##FM_COPY CONTAINER=ALL;

验证公共用户

-- 查询fm用户是在pdb下 为空是在cdb根目录

SELECT cu.USERNAME, cp.PDB_NAME, cu.COMMON, cu.CON_ID

FROM CDB_USERS cu

LEFT JOIN CDB_PDBS cp ON cu.CON_ID = cp.CON_ID

WHERE UPPER(cu.USERNAME) = 'C##FM_COPY';

本地用户(特定PDB)创建与管理

切换至目标PDB容器

ALTER SESSION SET CONTAINER=AODB; -- 替换为实际PDB名

创建本地用户

CREATE USER FM_LOCAL IDENTIFIED BY "Password123"

DEFAULT TABLESPACE FMTBS;

本地PDB内授权

GRANT DBA, CONNECT, RESOURCE TO FM_LOCAL;

容器切换操作

查询当前容器

SELECT SYS_CONTEXT('USERENV','CON_NAME') AS CURRENT_CONTAINER FROM DUAL;

切换至根容器

ALTER SESSION SET CONTAINER=CDB$ROOT;

切换至指定PDB

ALTER SESSION SET CONTAINER=IMF; -- 替换为实际PDB名

表空间管理

查询所有de表空间

SELECT

TABLESPACE_NAME,

STATUS,

CONTENTS,

EXTENT_MANAGEMENT

FROM

DBA_TABLESPACES ORDER BY TABLESPACE_NAME;

创建表空间(需指定PDB路径)

CREATE TABLESPACE FMTBS

DATAFILE '/u01/app/oracle/oradata/SAMP/IMF/fmtbs01.dbf'

SIZE 2G AUTOEXTEND ON;

验证表空间存在性

-- 查询表空间在当前pdb中是否存在

SELECT TABLESPACE_NAME, STATUS

FROM DBA_TABLESPACES

WHERE TABLESPACE_NAME='FMTBS';

用户删除操作

删除公共用户(需在根容器执行)

DROP USER C##FM_COPY CASCADE;

删除本地用户(需在对应PDB执行)

ALTER SESSION SET CONTAINER=AODB;

DROP USER FM_LOCAL CASCADE;

是否删除成功

-- 验证:删除后查询不到,说明成功

SELECT USERNAME FROM DBA_USERS WHERE USERNAME='C##FM_COPY';

总结

-- 查询所有pdb

SELECT PDB_NAME, STATUS FROM DBA_PDBS;

-- 是否是CDB根目录

SELECT SYS_CONTEXT('USERENV','CON_NAME') AS CURRENT_CONTAINER FROM DUAL;

-- 查询相关用户在那个pdb

SELECT

cu.USERNAME, -- 实际存储的用户名(大写/小写)

cp.PDB_NAME, -- fm用户所在的PDB(核心结果)

cu.COMMON, -- YES=公共用户(CDBROOT),NO=本地用户(某PDB)cu.CONID−−容器ID(1=CDBROOT),NO=本地用户(某PDB) cu.CON_ID -- 容器ID(1=CDBROOT),NO=本地用户(某PDB)cu.CONID−−容器ID(1=CDBROOT,其他=PDB)

FROM

CDB_USERS cu

LEFT JOIN

CDB_PDBS cp ON cu.CON_ID = cp.CON_ID

WHERE

UPPER(cu.USERNAME) = 'FM';

切换PDB

ALTER SESSION SET CONTAINER=AODB;

或者

ALTER SESSION SET CONTAINER=CDB$ROOT;

查询所有de表空间(判断表空间是否存在)

SELECT

TABLESPACE_NAME,

STATUS,

CONTENTS,

EXTENT_MANAGEMENT

FROM

DBA_TABLESPACES ORDER BY TABLESPACE_NAME;

-- 查询表空间在当前pdb中是否存在

SELECT TABLESPACE_NAME, STATUS FROM DBA_TABLESPACES WHERE TABLESPACE_NAME='FMTBS';

创建表空间

create tablespace fmtbs datafile '/u01/app/oracle/oradata/SAMP/aodb/fmtbs01.dbf' size 2G autoextend on;

创建用户

根目录创建用户名称 必须以C## 开头

CREATE USER C##FM_COPY IDENTIFIED BY "Tna@ssw0rd" DEFAULT TABLESPACE FMTBS;

授权 CONTAINER=ALL; -- 核心参数:全局授权,同步到所有PDB

grant dba,connect,resource,unlimited tablespace to C##FM_COPY ;

相关推荐
聆风吟º6 分钟前
金仓数据库 SQL 防火墙:内核级防护,筑牢 SQL 注入安全防线
数据库·sql·安全·金仓·kingbasees
码以致用13 分钟前
StarRocks的向量数据库能力
数据库·ai
2501_945423545 小时前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
gameboy0317 小时前
从MySQL迁移到PostgreSQL的完整指南
数据库·mysql·postgresql
xdl25997 小时前
Spring Boot中集成MyBatis操作数据库详细教程
数据库·spring boot·mybatis
回到原点的码农7 小时前
Spring Data JDBC 详解
java·数据库·spring
zb200641207 小时前
Spring Boot 实战:轻松实现文件上传与下载功能
java·数据库·spring boot
CSharp精选营7 小时前
SQL Server安装避坑:这8个奇葩报错你遇到过几个?
数据库·sql server·安装指南·避坑
一勺菠萝丶7 小时前
Flowable + Spring 集成踩坑:流程结束监听器查询历史任务为空 & 获取不到审批意见
java·数据库·spring
RDCJM8 小时前
mysql表添加索引
数据库·mysql