DataGrip操作Oracle

一、创建表空间

表名任意起,路径自己指定

复制代码
-- 创建表空间
create tablespace mydb1 -- 表名
datafile 'E:\Code\sql\oracle\oracle_tablespace\mydb1.dbf' --指定表空间路径
size 100M --指定表空间大小
autoextend on next 50M --指定一次扩充多少mb
extent management local autoallocate
segment space management auto;--Oracle会自动管理段的空间

二、表空间上创建用户

复制代码
-- 一个表空间可以建立多个用户
-- 创建用户 用户名密码
create user c##bluefox identified by manager
default tablespace mydb1; --指定用户在哪个表空间

注意:在Oracle12起创建用户需要在最前面加上c##,不然会报错

Oracle 12c引入了多租户容器数据库(CDB)和可插拔数据库(PDB)的概念,实现了实例和数据库之间一对多的关系。在CDB中,创建的用户默认为全局用户,需要在用户名前加上"C##"前缀,以在CDB和所有的PDB中创建该用户。

三、给用户赋DBA权限

一般来说赋予dba权限就够用了。

复制代码
-- 给用户赋DBA权限及其他权限
grant dba,connect,resource,
aq_administrator_role,aq_user_role
to c##bluefox

1、grant dba: DBA是Oracle数据库中的一个超级用户角色,拥有该角色的用户可以执行任何数据库操作。通常,出于安全考虑,不会将DBA角色授予普通用户,除非该用户确实需要执行高级管理任务。

2、grant connect: CONNECT角色允许用户连接到数据库。这是大多数用户都需要的基本权限。

3、grant resource: RESOURCE角色允许用户创建表、序列、触发器、过程、函数等。这也是一个常见的角色,用于授予用户创建数据库对象的能力。

4、grant aq_administrator_role: AQ_ADMINISTRATOR_ROLE是Oracle高级队列(Advanced Queuing)的一个角色,允许用户管理队列和队列相关的对象。如果你的应用使用了高级队列功能,那么可能需要这个角色。

5、grant aq_user_role: AQ_USER_ROLE也是高级队列的一个角色,但权限较AQ_ADMINISTRATOR_ROLE为少。它允许用户使用队列,但不允许管理队列。

四、编写SQL

配置完成就能正常编写sql语句了

相关推荐
Element_南笙24 分钟前
吴恩达新课程:Agentic AI(笔记2)
数据库·人工智能·笔记·python·深度学习·ui·自然语言处理
长安城没有风29 分钟前
从入门到精通【Redis】Redis 典型应⽤ --- 分布式锁
数据库·redis·分布式
Ytadpole30 分钟前
MySQL 数据库优化设计:优化原理和数据库表设计技巧
数据库·mysql·优化·索引·查询·检索·表设计
christine-rr1 小时前
数据库基础概念体系梳理
数据库·oracle
SirLancelot11 小时前
StarRocks-基本介绍(一)基本概念、特点、适用场景
大数据·数据库·数据仓库·sql·数据分析·database·数据库架构
Boop_wu2 小时前
[MySQL] 基础操作
数据库·mysql
6极地诈唬2 小时前
【sqlite】xxx.db-journal是什么?
数据库·sqlite
小糖学代码3 小时前
MySQL:14.mysql connect
android·数据库·mysql·adb
爬山算法4 小时前
Redis(69)Redis分布式锁的优点和缺点是什么?
数据库·redis·分布式
RestCloud4 小时前
从数据库到价值:ETL 工具如何打通南大通用数据库与企业应用
数据库