Oracle 12c创建用户时为什么要在用户名前加”C##"?
来源:互联网 发布:hbuilder 商城app源码 编辑:程序博客网 时间:2024/06/06 07:25
Oracle 12C引入了CDB与PDB的新特性,在ORACLE 12C数据库引入的多租用户环境(Multitenant Environment)中,允许一个数据库容器(CDB)承载多个可插拔数据库(PDB)。CDB全称为Container Database,中文翻译为数据库容器,PDB全称为Pluggable Database,即可插拔数据库。在ORACLE 12C之前,实例与数据库是一对一或多对一关系(RAC):即一个实例只能与一个数据库相关联,数据库可以被多个实例所加载。而实例与数据库不可能是一对多的关系。当进入ORACLE 12C后,实例与数据库可以是一对多的关系。下面是官方文档关于CDB与PDB的关系图。
CDB组件(Components of a CDB)
一个CDB数据库容器包含了下面一些组件:
ROOT组件
ROOT又叫CDB$ROOT, 存储着ORACLE提供的元数据和Common User,元数据的一个例子是ORACLE提供的PL/SQL包的源代码,Common User 是指在每个容器中都存在的用户。
SEED组件
Seed又叫PDB$SEED,这个是你创建PDBS数据库的模板,你不能在Seed中添加或修改一个对象。一个CDB中有且只能有一个Seed. 这个感念,个人感觉非常类似SQL SERVER中的model数据库。
PDBS
CDB中可以有一个或多个PDBS,PDBS向后兼容,可以像以前在数据库中那样操作PDBS,这里指大多数常规操作。
这些组件中的每一个都可以被称为一个容器。因此,ROOT(根)是一个容器,Seed(种子)是一个容器,每个PDB是一个容器。每个容器在CDB中都有一个独一无二的的ID和名称。
怎么查看数据库是否为CDB?
执行下面这条语句:
select CDB from v$database;
如果得到的结果为YES,那么就是CDB的数据库,否则,则不是。
怎么查看当前的容器?
执行下面这条语句:
show con_name;
怎么查看CDB中的PDB信息?
执行下面这条语句:
select con_id, dbid, guid, name , open_mode from v$pdbs;
执行结果如下:
那么说了这么多,怎么就可以创建用户而不用加c##了呢,我在这里创建一个新的数据库,步骤如下:
打开 Database Configuration Assistant
出现如下界面:
点击“下一步”出现如下界面,在创建数据库的时候将“创建为容器数据库”项取消勾选。
这样新创建的数据库就可以使用了。
- Oracle 12c创建用户时为什么要在用户名前加”C##"?
- oracle 12c创建用户
- Oracle 12C 创建用户
- Oracle 12c创建用户
- C语言中为什么scanf会在赋值的变量前加&
- oracle 12c创建pdb用户
- Oracle 12c如何创建scott用户
- Oracle 12C 创建用户连接pdb
- oracle 12C 创建用户失败 解决方案
- 在Oracle Database 12c 中创建c##scott用户及相关数据表
- oracle 12c 创建公共用户和本地用户
- C语言中用scanf函数输入字符时,为什么要在输入控制符%c前面加空格?
- 在C++中调用被C编译器编译后的函数,为什么要加extern "C"
- 为什么在C++里调用被C编译器编译的函数,要加extern "c"
- C语言中static加在函数声明前
- 补.从零开始学习C语言--scanf的%c前为什么加空格
- oracle 12c 创建PDB用户即Local User
- Oracle Database 12c cdb/pdb用户的创建
- Java中ArrayList和LinkedList区别 时间复杂度 与空间复杂度
- JAVA简述
- (洛谷 1908)逆序对
- android 什么时候用总线模式合适?
- 下载gradle地址
- Oracle 12c创建用户时为什么要在用户名前加”C##"?
- 责任链模式和状态模式对比
- 购物车的activity
- Spring Cloud Eureka 服务注册与发现
- 69. Sqrt(x)
- 85. Maximal Rectangle
- LeNet模型解读
- 在centos中安装了mysql5.7之后解决不知道随机的密码的问题
- Linux命令中:rsync和cp之间的区别