一.oracle 12c安装
- 安装最后一步要注意,如装有360等杀毒软件可能会阻止oracle向系统写入的一些操作,没有及时点击同意会照成安装报错;及时点击重试成功后也可能造成oracle不好用。
- 安装最后一步没有弹出口令管理界面,可使用sys用户进行登录。
注:
用户:sys 密码:sys 登录命令 conn sys/sys as sysdba; 超级管理员,权限最高,它的角色是DBA(数据库管理员)。默认密码是change_on_install。具有创建数据库的权限。
用户:system 密码:manager 登录命令 conn system/manager as sysdba; 系统管理员,权限很高,它的角色是DBA operator(数据库管理员操作者),默认密码manager。不具有创建数据库的权限!
二.plsql安装
安装环境:win10 64位、plsql为9.0版本 32位、oracle12c为64位
- 安装plsql报错如下,原因安装完后Oracle的 oci.dll 是64位的,而32位应用程序 PLSQL Developer 无法加载。
Initialization error
Could not initialize "C:\oracle\product\11.2.0\dbhome_1\bin\oci.dll"
Make sure you have the 32 bits Oracle Client installed.
OCIDLL forced to C:\oracle\product\11.2.0\dbhome_1\bin\oci.dll
LoadLibrary(C:\oracle\product\11.2.0\dbhome_1\bin\oci.dll) returned 0
解决方案(解决oracle和plsql之间不匹配问题)
-
1.重新安装plsql为11版本64位,登陆成功。
-
2.从 http://www.oracle.com/technetwork/database/features/instant-client/index-097480.html 下载Oracle Client Package。 我下载的是Instant Client for Microsoft Windows (32-bit) 【instantclient-basic-nt-11.2.0.2.0.zip】
-
将 instantclient-basic-nt-11.2.0.2.0.zip 解压至 c:\oracle, oci.dll 所在目录为:c:\oracle\instantclient_11_2\
-
设置环境变量
TNS_ADMIN=c:\oracle\product\11.2.0\dbhome_1\NETWORK\ADMIN
NLS_LANG=AMERICAN_AMERICA.ZHS16GBK (注:NLS_LANG前半部分必须是AMERICAN_AMERICA,因为instant client不支持其他语言;而后半部分可以根据你数据库的字符集调整,如果数据库采用AL32UTF8,则可以设置AL32UTF8) -
启动PL/SQL Developer ,点击“取消”不要登录,菜单 --> Tools --> Perferences --> Connection 修改 Oracle_Home 和 OCI Library 的配置:
OracleHome: OraDb11g_home1
OCI library: C:\oracle\instantclient_11_2\oci.dll -
重新启动 PL/SQL并登录对应的数据库,登录界面出现connect as 连接正常,问题成功解决!
三.新建表空间及用户
create tablespace TEST_DATA(表空间名)
logging
datafile 'D:\app\oracle_tablespace\CBD_TEST_DATA.dbf'
size 50m
autoextend on
next 50m maxsize 20480m
extent management local;
create user c##test(用户名) identified by test(密码) default tablespace TEST_DATA;
grant dba to c##test(用户名);
grant create session to c##test(用户名);
grant create table to c##test(用户名);
grant unlimited tablespace to c##test(用户名);
#12c创建用户时可以不加C##前缀
alter session set "_ORACLE_SCRIPT" = true;
- Oracle12c 中,增加了可插接数据库的概念,即PDB,允许一个数据库容器(CDB)承载多个可插拔数据库(PDB)。CDB全称为 ContainerDatabase,中文翻译为数据库容器,PDB全称为PluggableDatabase,即可插拔数据库。下面是官方文档关于CDB与PDB的关系图。
- 在CDB中,只能创建以c##或C##开头的用户,如果不加c##,则会提示错误“ORA-65096:公用用户名或角色名无效”,只有在PDB数据库中才能创建我们习惯性命名的用户,oracle称之为Local User,前者称之为Common User。本文主要解决如何创建DPB用户并设置默认表空间全过程。
需要注意:
1.在CDB中新建的表空间,要在每个PDB中重建一次空间名一致指向datafile不同。
2.用户名以c##开头。
查看PDB命令:
show pdbs;
切换到pbd下的命令:
alter session set container=ORCLPDB;
切回cbd命令:
alter session set container=cdb$root;