oracle12c 安装和使用-plsql变量

环境

win10 64位
Oracle Database 12c Release 2 (12.2.0.1.0)

1.下载

数据库(包括客户端)
Oracle Database 12c Release 2 (12.2.0.1.0) for Microsoft Windows (x64)
客户端
Oracle Database 12c Release 2 Client (12.2.0.1.0) for Microsoft Windows (x64)

https://www.oracle.com/database/technologies/oracle12c-windows-downloads.html

客户端下载: https://www.oracle.com/database/technologies/instant-client/downloads.html

2.安装

安装完成
Oracle Enterprise Manager Database Express URL: https://localhost:5500/em
在这里插入图片描述

按照步骤安装好后,需要启动监听 lnsrctl start

#查看监听
lnsrctl status
#关闭监听
lnsrctl stop
#启动监听
lnsrctl start

修改监听名

服务器中的listener.ora
在这里插入图片描述
客户端配置

LOCALHOST =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SID = ORCL)
    )
  )

启动实例连接本地数据库失败

ORA-28547:连接服务器失败,可能是Oracle Net管理错误
 描述:监听和服务都正常启动了,但是远程连接的时候会有这种错误

  ORA-28547:连接服务器失败,可能是Oracle Net管理错误

 解决办法:

listener.ora 文件中

DEFAULT_SERVICE_LISTENER= (ORCL) 
 
SID_LIST_LISTENER = 
  (SID_LIST = 
    (SID_DESC = 
      (SID_NAME = orcl)           #网络上的服务名称 
      (ORACLE_HOME =G:\oracle\product\10.2.0\db_1) # 这里一定要配置正确 
#      (PROGRAM = extproc) 
    ) 
  ) 
 (PROGRAM = extproc)  把这句话注释掉重启监听服务就好了。

 extproc是一个扩展的程序调用接口协议,  连接和调用外部的操作系统程序或进程用时会用到。

3.默认用户名密码

创建数据库时设置口令为 rootA123 替换sys 默认密码,远程使用sys登陆时使用此密码登陆。在本机使用sys登陆则不需要密码

SYS用户:超级管理员,权限最高,它的角色是DBA。默认密码是change_on_install。具有创建数据库的权限
SYSTEM用户:系统管理员,权限很高,它的角色是DBA operator,默认密码manager。不具有创建数据库的权限!
普通用户(normal),如系统安装时的scott用户,默认密码是tiger。普通用户的权限是SYS用户或SYSTEM用户给的,如果没有给,那普通用户连很基本的访问权限,连接权限也没有。以上说的默认密码是9i时的默认密码,10g时已经没有默认密码了。

使用PLSQL可以使用sys / as sysdba登陆

4.新增用户

新建一个数据库就可以和11g一样直接创建用户和密码。如果使用12c的方式(容器数据库)则需要加c##或C##为用户名前缀

create user scott identified by tiger;
grant connect,resource,dba to scott;

修改用户密码

-- 容器数据库添加用户 用户名不区分大小写,密码区分大小写
create user c##scott identified by tiger;
grant connect,resource,dba to c##scott;

-- 修改用户密码 alter user abc identified by 123456;//修改用户名abc密码123456

常用命令

一、查看用户


1.查看所有用户:
select * from dba_users;
select * from all_users;
select * from user_users;    //查看当前用户


二、查看角色

1.当前用户被激活的全部角色
  select * from session_roles;


2.当前当前用户被授予的角色
  select * from user_role_privs;


3.全部用户被授予的角色
  select * from dba_role_privs;


4、查看某个用户所拥有的角色

select * from dba_role_privs where grantee='用户名';

 

5、查看某个角色所拥有的权限

select * from dba_sys_privs where grantee='CONNECT';

 

6.查看所有角色
  select * from dba_roles;



三、查看权限

1.基本权限查询:
select * from session_privs; --当前用户所拥有的全部权限
select * from user_sys_privs;--当前用户的系统权限
select * from user_tab_privs;--当前用户的对象权限
select * from dba_sys_privs ;--查询某个用户所拥有的系统权限
select * from role_sys_privs;--查看角色(只能查看登陆用户拥有的角色)所包含的权限


2. 查看用户的系统权限(直接赋值给用户或角色的系统权限)
select * from dba_sys_privs;

select * from user_sys_privs;


2.查看用户的对象权限:
 select * from dba_tab_privs;
 select * from all_tab_privs;
 select * from user_tab_privs;


3.查看哪些用户有sysdba或sysoper系统权限(查询时需要相应权限)
  select * from v$pwfile_users; 

扩展

1、以下语句可以查看Oracle提供的系统权限
select name from sys.system_privilege_map

2、查看一个用户的所有系统权限(包含角色的系统权限)
select privilege from dba_sys_privs where grantee='SCOTT'  
union  
select privilege from dba_sys_privs where grantee in (select granted_role from dba_role_privs where grantee='SCOTT' ); 

 

3、 查询当前用户可以访问的所有数据字典视图。 
select * from dict where comments like '%grant%';   
 

4、显示当前数据库的全称
select * from global_name;   

 

问题 1:如何查询一个角色包括的权限?   
a.一个角色包含的系统权限   
         select * from dba_sys_privs where grantee='角色名'  

         select * from dba_sya_privs where grantee='COONNECT'; connect要大写
         另外也可以这样查看:   
         select * from role_sys_privs where role='角色名'   
b.一个角色包含的对象权限   
         select * from dba_tab_privs where grantee='角色名'   


问题 2:Oracle究竟有多少种角色?   
select * from dba_roles;   


问题 3:如何查看某个用户,具有什么样的角色?   
select * from dba_role_privs where grantee='用户名'  

 

问题4:查看哪些用户具有DBA的角色

select grantee from dba_role_privs where granted_role='DBA';

授权

# 授权表空间权限 alter user ${userName} quota unlimited on USERS
alter user c##scott quota unlimited on USERS

# 授权用户dba权限 grant connect,resource,dba to ${userName}
grant connect,resource,dba to c##scott

PLSQL

变量设置

pl/sql环境变量设置

ORACLE_HOME=D:\oracle\product\10.2.0\db_1


TNS_ADMIN=D:\oracle\product\10.2.0\db_1\NETWORK\ADMIN


NLS_LANG=SIMPLIFIED CHINESE_CHINA.ZHS16GBK

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值