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语句了

相关推荐
swordbob6 分钟前
MySQL字符集陷阱:从Oracle迁移踩坑到utf8mb4强制规范
数据库·sql
牛油果子哥q20 分钟前
【C++ STL string 】C++ STL string 终极精讲:底层原理、内存机制、全套API、深浅拷贝、易错坑点与工程实战规范
数据库·c++
十五年专注C++开发21 分钟前
MySql中各种功能用sql语句实现总结
数据库·sql·mysql
数据库小学妹38 分钟前
AI时代数据库怎么选?多模融合、数据统一存储与选型实战指南
数据库·人工智能·经验分享·ai
Albert Edison1 小时前
【Redis】Centos7.9 安装 Redis 5 教程
数据库·redis·缓存
云计算磊哥@1 小时前
运维开发宝典026-MySQL02数据库表操作
运维·数据库·运维开发
小二·1 小时前
Redis 内存溢出(OOM)排查与恢复实战
数据库·redis·bootstrap
pqk6V6Vep1 小时前
Redis 分布式锁进阶第一篇讲解
数据库·redis·分布式
giaz14n9X2 小时前
Redis 分布式锁进阶第六十一篇
数据库·redis·分布式
是一个Bug2 小时前
MongoDB:像搭积木一样存数据
数据库·mongodb