oracle 的 Schema

1. 最简单理解

Oracle 里:Schema = 用户名 + 这个人名下所有表/视图/存储过程/对象的集合

👉 一个用户 = 一个 Schema

👉 你创建一个用户,就自动生成一个独立 Schema

MySQL / SQL Server 里叫「数据库/库

👉 Oracle 没有库的概念,靠 Schema 来隔离


2. Schema 具体是干嘛的?

① 用来隔离数据、分类存放

不同业务、不同项目、不同模块,分开装:

  • 财务用户(finance)→ 财务Schema
  • 人事用户(hr)→ 人事Schema
  • 订单用户(order)→ 订单Schema

各自的表互不干扰。


② 权限隔离(非常关键)

A Schema 不能随便看 B Schema 的表

需要授权:

sql 复制代码
grant select on hr.emp to finance;

企业里权限安全全靠 Schema 控制


③ 统一管理一堆数据库对象

Schema 里面装的所有东西:

  • 表 table
  • 视图 view
  • 索引 index
  • 存储过程、函数
  • 触发器
  • 序列 sequence

相当于一个大文件夹,所有对象打包在一起。


3. 举个最直观例子

我创建用户:

sql 复制代码
create user test1 identified by 123456;

✅ 此时:

  • test1 就是一个 Schema
  • 你登录 test1 建的所有表,都属于 test1 这个 Schema

查别人表要写:

sql 复制代码
select * from test2.user_info;

格式:Schema名.表名


4. 和 MySQL 区别(很多人搞混)

  • MySQL:
    • 一台库 → 分很多 database(库)
  • Oracle:
    • 一台库 → 分很多 schema(用户)

等价关系:

MySQL 库 ≈ Oracle Schema


5.一句话终极总结

  1. Oracle 没有"数据库"这个分层,用 Schema 代替。
  2. 一个用户 = 一个 Schema。
  3. 用来分组存表、隔离业务、控制权限。
  4. 写 SQL 时 用户名.表名 就是在指定 Schema。
相关推荐
weelinking4 小时前
【产品】00_产品经理用Claude实现产品系列介绍
数据库·人工智能·sql·数据挖掘·github·产品经理
2301_803934615 小时前
Go语言如何做网络爬虫_Go语言爬虫开发教程【指南】
jvm·数据库·python
秋96 小时前
windows中安装redis
数据库·redis·缓存
Cosolar6 小时前
万字详解:RAG 向量索引算法与向量数据库架构及实战
数据库·人工智能·算法·数据库架构·milvus
想唱rap6 小时前
IO多路转接之poll
服务器·开发语言·数据库·c++
SeaTunnel6 小时前
AI 让 SeaTunnel 读源码和调试过时了吗?
大数据·数据库·人工智能·apache·seatunnel·数据同步
凯瑟琳.奥古斯特7 小时前
数据冗余与规范化的本质[数据库原理]
开发语言·数据库·职场和发展
_ku_ku_7 小时前
数据库系统原理 · SQL 数据定义、更新及数据库编程 · 自学总结
数据库·oracle
Mortalbreeze7 小时前
深度理解文件系统 ---- 从磁盘存储到内核存储
大数据·linux·数据库
2301_803934617 小时前
MySQL 字段类型选择规范指南
jvm·数据库·python