Oracle 笔记

Oracle 笔记

这里主要是记录学习 Oracle 常用操作命令等,方便今后查阅!!!

一、常用命令

登录Oracle

su - oracle

export ORACLE_SID=XE
export ORAENV_ASK=NO
. /opt/oracle/product/21c/dbhomeXE/bin/oraenv

sqlplus system/1qaz2WSX

-- 切换到sys用户
conn / as sysdba

查看当前所有的数据库

select * from v$database;select name from v$database;

查看哪些用户拥有sysdba、sysoper权限

select * from V_$PWFILE_USERS;

--查看当前数据库连接用户
show user;

查看所有表

-- 系统里有权限的表
SELECT * FROM ALL_TABLES;

-- 系统表
SELECT * FROM DBA_TABLES; 

-- 当前用户下的表
SELECT * FROM USER_TABLES; 

进入某个数据库
database 数据库名;

-- 查看数据库结构
desc v$database;

查看所有用户实例:

select * from v$instance;select instance_name from v$instance;

查看当前库的所有数据表

select * from all_tables;
select table_name from all_tables;
select table_name from user_tables;
select table_name from all_tables where owner='用户名';

查看表结构

desc table_name;

增加数据库用户

create user 用户名 identified by 密码 default tablespace users Temporary TABLESPACE Temp

用户授权

grant connect,resource,dba to 用户名;
grant sysdba to 用户名;
 更改数据库用户密码
alter user 用户名 identified by 密码;

二、创建用户

登录之后就可以创建用户了

create user test identified by 123456;
注意:12c的版本肯定会报错:
ORA-65096: 公用用户名或角色名无效

创建用户的时候用户名以c##或者C##开头即可。
错误写法: create user test    identified by 123456;
正确写法: create user c##test identified by 123456;

给用户权限

创建成功以后就需要给新建用户权限

-- 授予c##test用户创建session的权限,用来登录
grant create session to c##test;

-- 授予c##test用户使用表空间的权限
grant unlimited session to c##test;

-- 授予创建表的权限
grant create table to c##test;

-- 授予删除、插入、修改表的权限
grant drop table to c##test;
grant insert table to c##test;
grant update table to c##test;

授权标准角色

(即系统默认权限的集合CONNECT、RESOURCE、DBA)

 grant connect, resource to c##test;

oralce对权限管理比较严谨,普通用户之间也是默认不能互相访问的
如果想让c##test拥有访问其他表的权限,则需要以下命令
-- 授予c##test用户查看指定表的权限
grant select on tablename to c##test;

-- 授予删除表的权限 
grant drop on tablename to c##test;

-- 授予插入的权限 
grant insert on tablename to c##test;

-- 授予修改表的权限 
grant update on tablename to c##test;
grant insert(id) on tablename to c##test; 

-- 授予对指定表特定字段的插入和修改权限,注意,只能是insert和update 
grant update(id) on tablename to c##test;

-- 授予c##test用户alert任意表的权限 
grant alert all table to c##test;

撤销用户权限

-- 移除c##test用户创建session的权限
revoke create session from c##test;

-- 移除c##test用户使用表空间的权限
revoke unlimited session from c##test;

-- 移除创建表的权限
revoke create table from c##test;

-- 移除删除表的权限
revoke drop table from c##test;

-- 移除插入表的权限
revoke insert table from c##test;

-- 移除修改表的权限
revoke update table from c##test;

-- 移除所有用户(public)所有权限(all) 
revoke all from public;

等等···和授予权限语法基本都是一样的,除了关键字

查看权限

-- 查看当前用户所有权限 
select * from user_sys_privs;

-- 查看所用用户对表的权限 
select * from user_tab_privs;

-- 查看当前用户所有权限 
select * from user_sys_privs;
select * from user_tab_privs;//查看所用用户对表的权限 

角色

(即权限的集合,可以把一个角色授予给用户 )

-- 创建角色 
create role myrole;

-- 将创建session的权限授予myrole 
grant create session to myrole;

-- 授予c##test用户myrole的角色
grant myrole to c##test;

-- 删除角色 
drop role myrole;
但是有些权限是不能授予给角色的,比如unlimited table

关注林哥,持续更新哦!!!★,°:.☆( ̄▽ ̄)/$:.°★ 。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
孟老师 oracle笔记中记录了他在学习和应用Oracle数据库管理系统过程中的重要知识点和经验总结。这些笔记对他个人来说是非常宝贵的学习工具,并且也可以分享给其他学习者。 首先,孟老师的笔记内容包括了Oracle数据库的概述和架构。他对Oracle数据库系统的组成部分、存储结构、进程和线程等进行了详细的介绍。这使得他自己能够更好地理解Oracle数据库的运行原理,从而能够更好地进行数据库管理和优化。 其次,他的笔记中也包含了Oracle数据库的安装和配置过程。他记录了安装过程中可能遇到的问题和解决方法,还有如何正确配置数据库参数以满足具体的需求。这部分内容非常实用,它可以帮助他在以后的实际应用中更加高效地进行数据库的部署和配置。 此外,孟老师还记录了Oracle数据库的备份和恢复策略。他介绍了不同的备份方法,如完全备份、增量备份和重写备份,并指出了每种备份方法的适用场景。在笔记中,他还总结了一些关键的恢复指令和技巧,以便在意外故障发生时能够及时应对。 最后,他还在笔记中分享了一些常见问题和实践经验。这些问题和经验既包括技术层面的,如如何提高数据库性能和调优查询语句,也包括管理层面的,如如何规划数据库用户和权限管理。这些实践经验对于其他Oracle学习者来说是非常宝贵的参考资料。 总体来说,孟老师的Oracle笔记是一个非常有用的学习资源。它不仅记录了他个人的学习过程和经验总结,也为其他学习者提供了重要的参考和指导,帮助他们更好地理解和应用Oracle数据库管理系统。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值