zoukankan      html  css  js  c++  java
  • 分享知识-快乐自己:oracle12c创建用户提示ORA-65096:公用用户名或角色无效

    今天在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

    出现如下界面:

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

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

  • 相关阅读:
    [IOI1994][USACO1.5]数字三角形 Number Triangles
    和为给定数
    小凯的疑惑
    棋盘
    【2020NOI.AC省选模拟#2】C. 送分题
    【NOI OL #2】涂色游戏
    【NOI OL #3】小结
    【NOI OL #1】最小环
    【NOI OL #1】冒泡排序
    【NOI OL #1】序列
  • 原文地址:https://www.cnblogs.com/mlq2017/p/9897947.html
Copyright © 2011-2022 走看看