今天在oracle12c上创建用户,报错了。如下图:

我很郁闷, 就打开了oracle官方网站找了下, 发现创建用户是有限制的。

2.解决方案

创建用户的时候用户名以c##或者C##开头即可。

错误写法: create user zhaojiedi identified by oracle;
正确写法: create user c##zhaojiedi identified by oracle;

注: 如果你不纠结为啥的,上面的解决方案就可以满足你的要求了,下面的内容可以不用看了。

========================================================================

========================================================================

3. 解决过程

下面的流程是我对于这个问题的解决过程, 也写出来分享分享。

我进入oracle 12c官方文档的

依次进入以下页面

oracle12c主页

Administrator's Guide

Managing Users and Securing the Database

Oracle Database Security Guide

Creating User Accounts

经过一番查找,在Creating User Accounts 页面找到了如下图的内容:

上面提示的很明确了。 创建公共用户名必须要以c##或者C##开头了。我们上面的报错了。 就是因为我们创建公共用户没用以c##或者C##开头的。

到此我们就知道具体错误的原因了。 那就赢的解决方案就有了哈。

如果你还纠结公用用户和本地用户是啥东东的,Creating User Accounts 页面就有简介。

========================================================================

有些不明白,然后继续查资料,原因是这样的:

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;

执行结果如下:

启动PDB数据库的方式:执行下面这条语句:

alter pluggable database PDBORCL open;

执行结果如下:

关闭PDB数据库的方式:执行下面这条语句:

alter pluggable database PDBORCL close;

执行下面这条语句:

在容器间切换:

alter session set container=PDBORCL;
alter session set container=CDB$ROOT;

--------------------------------------------------------------分割线------------------------------------------------------------------------

那么说了这么多,怎么就可以创建用户而不用加c##了呢,我在这里创建一个新的数据库,步骤如下:

打开 Database Configuration Assistant

出现如下界面:

点击“下一步”出现如下界面,在创建数据库的时候将“创建为容器数据库”项取消勾选。

这样新创建的数据库就可以使用了。

转载于:https://www.cnblogs.com/mlq2017/p/9897947.html

分享知识-快乐自己:oracle12c创建用户提示ORA-65096:公用用户名或角色无效相关推荐

  1. oracle12c用户名c##_Oracle数据库之oracle12c创建用户提示ORA-65096:公用用户名或角色无效...

    本文主要向大家介绍了Oracle数据库之oracle12c创建用户提示ORA-65096:公用用户名或角色无效,通过具体的内容向大家展现,希望对大家学习Oracle数据库有所帮助. 1.背景 以前一直 ...

  2. oracle12c 创建新用户报错ORA-65096:公用用户名或角色名无效”解决方法

    oracle 12c创建用户需要添加C##或c## 创建一个用户名为user1密码为password1的用户 CREATE USER C##user1 IDENTIFIED BY password1 ...

  3. oracle 12c新特性(1)——创建新用户(公用用户名或角色名无效)

    GRANT CONNECT,RESOURCE,UNLIMITED TABLESPACE TO C##SCOTT IDENTIFIED BY TIGER container=all; ALTER USE ...

  4. oracle错误65096,oracle12创建用户错误ORA-65096: 公用用户名或角色名无效

    ora-65096解决方案 创建用户命令: create user newuser identified by newuser; 报错:ORA-65096: invalid common user o ...

  5. Oracle sql plus创建用户时出现:ORA-65096: 公用用户名或角色名无效

    Oracle sql plus创建用户时出现:ORA-65096: 公用用户名或角色名无效 执行 alter session set "_ORACLE_SCRIPT"=true; ...

  6. Oracle12c创建用户不加C##

    Oracle12c数据库的创建用户的方式有所改变,因为Oracle 12C引入了CDB与PDB的新特性,具体特性就不多说了,感兴趣可查看官方文档.因此,我们平时所用的创建用户的命令也有所变化,必须得加 ...

  7. oracle12C 创建用户学习

    Oracle 12C中,账号分为两种,一种是公用账号,一种是本地账号(亦可理解为私有账号).共有账号是指在CDB下创建,并在全部PDB中生效的账号,另一种是在PDB中创建的账号. 针对这两种账号的测试 ...

  8. 解决达梦数据库DM8创建用户提示:“密码长处不符合要求”问题

    达梦8创建用户 "密码长度不符合要求" 问题解决 从达梦7过渡到了达梦8,新版本数据库我们发现dm.ini中已经找不到配置密码策略的选项了,然而遇到数据库密码必须配合应用设置为固定 ...

  9. 命令怎么创建oracle用户,Oracle 如何使用命令行创建用户

    Oracle 创建用户.解锁.授权.登录等操作 首先Oracle下载安装,然后打开cmd命令行: 输入: sqlplus sys/sys as sysdba; (以sys超级管理员的权限去登录orac ...

最新文章

  1. 【云周刊】第126期:硬货!云存储成本到底省在哪儿
  2. Quartz1.X中CronTrigger第一次启动的问题
  3. python之Django部署
  4. 疯狂软件2月3日Android就业班课程详细
  5. java的oauth2.0_[转]Java的oauth2.0 服务端与客户端的实现
  6. python 文本文件处理_53 Python - txt普通文件处理
  7. C++|Qt工作笔记-对explicit的认识(Qt中一般情况下为什么会自动加上这个关键字)
  8. java 内存溢出分析_用一段时间后java内存溢出问题分析(转)
  9. IAR编译器中函数智能提示
  10. 服务器遭受***后的处理过程
  11. 股票历史数据下载接口汇总(动态更新)
  12. Java开发 音视频会议
  13. Fragstats计算景观格局指数(初学指南)
  14. segue 分析小结
  15. 【BDTC 2016】网络与通讯大数据论坛:大数据价值及合规性探索
  16. 【webrtc0419 点对点视频聊天功能】
  17. Android Studio4.0以上设置护眼背景色
  18. ORA-00600 内部错误代码, 参数 [19004]
  19. 敏捷研发(Scrum)
  20. 三极管开关电路参数设计与参数介绍

热门文章

  1. 《财富》公布40岁以下美国富豪榜 戴尔居榜首 [我在IT meets Coupon里提到的两个均在其列]...
  2. Elasticsearch 跨机房灾备方案实战(一) —— 消息队列实现双写
  3. java 判断是否是罗马_如何只使用正则表达式匹配有效的罗马数字?
  4. 【MD】markdown符号表
  5. 基于php的微信公众平台开发入门实例
  6. MySQL-Parser
  7. 猜想2010年IT十大表情
  8. 基于keras的mnist手写体识别程序
  9. SQL查询优化方法 提高SQL查询效率 数据库的哪些字段适合添加索引
  10. 《最新开源 随插即用》SAM 自增强注意力深度解读与实践(附代码及分析)