oracle中schema指的是什么?

oracle中schema指的是什么?

看来有的人还是对schema的真正含义不太理解,如今我再次整理了一下,希望对大家有所帮助。

我们先来看一下他们的定义:
A schema is a collection of database objects (used by a user.).
Schema objects are the logical structures that directly refer to the database’s data.
A user is a name defined in the database that can connect to and access objects.
Schemas and users help database administrators manage database security.

从定义中我们能够看出schema为数据库对象的集合,为了区分各个集合,我们须要给这个集合起个名字,这些名字就是我们在企业管理器的方案下看到的很多相似username的节点,这些相似username的节点事实上就是一个schema,schema里面包括了各种对象如tables, views, sequences, stored procedures, synonyms, indexes, clusters, and database links。

一个用户一般相应一个schema,该用户的schema名等于username,并作为该用户缺省schema。这也就是我们在企业管理器的方案下看到schema名都为数据库username的原因。Oracle数据库中不能新创建一个schema,要想创建一个schema,仅仅能通过创建一个用户的方法解决(Oracle中尽管有create schema语句,可是它并非用来创建一个schema的),在创建一个用户的同一时候为这个用户创建一个与username同名的schem并作为该用户的缺省shcema。即schema的个数同user的个数同样,并且schema名字同user名字一一 相应并且同样,全部我们能够称schema为user的别名,尽管这样说并不准确,可是更easy理解一些。

一个用户有一个缺省的schema,其schema名就等于username,当然一个用户还能够使用其它的schema。假设我们訪问一个表时,没有指明该表属于哪一个schema中的,系统就会自己主动给我们在表上加上缺省的sheman名。比方我们在訪问数据库时,訪问scott用户下的emp表,通过select * from emp; 事实上,这sql语句的完整写法为select * from scott.emp。在数据库中一个对象的完整名称为schema.object,而不属user.object。相似假设我们在创建对象时不指定该对象的schema,在该对象的schema为用户的缺省schema。这就像一个用户有一个缺省的表空间,可是该用户还能够使用其它的表空间,假设我们在创建对象时不指定表空间,则对象存储在缺省表空间中,要想让对象存储在其它表空间中,我们须要在创建对象时指定该对象的表空间。

咳,说了这么多,给大家举个样例,否则,一切枯燥无味!
SQL> Gruant dba to scott

SQL> create table test(name char(10));
Table created.

SQL> create table system.test(name char(10));
Table created.

SQL> insert into test values(‘scott’);
1 row created.

SQL> insert into system.test values(‘system’);
1 row created.

SQL> commit;
Commit complete.

SQL> conn system/manager
Connected.

SQL> select * from test;
NAME
———-
system

SQL> ALTER SESSION SET CURRENT_SCHEMA = scott; –改变用户缺省schema名
Session altered.

SQL> select * from test;
NAME
———-
scott

SQL> select owner ,table_name from dba_tables where table_name=upper(‘test’);
OWNER TABLE_NAME
—————————— ——————————
SCOTT TEST
SYSTEM TEST
–上面这个查询就是我说将schema作为user的别名的根据。实际上在使用上,shcema与user全然一样,没有什么差别,在出现schema名的地方也能够出现user名。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/119232.html原文链接:https://javaforall.net

(0)
上一篇 2021年11月13日 下午11:00
下一篇 2021年11月14日 上午6:00


相关推荐

  • 【Robo 3T】MongoDB可视化工具– Robo 3T使用教程

    【Robo 3T】MongoDB可视化工具– Robo 3T使用教程MongoDB 可视化工具 Robo3T 使用教程 1 到官网下载 Robo3T 网址如 https robomongo org download 2 下载安装成功后 打开后点击左上角的 create 创建一个连接 给该连接起个名字 如 localhost 使用默认地址 localhost 和端口 27017 即可 点击 save 保存 如下图所示 3 点击保存后 就会在界面看到如下图所示 4 双击 localhost 连接到 MongoDB 并进入交互界面 我们可以看

    2026年3月16日
    2
  • labview如何旋转控件_labview怎么用

    labview如何旋转控件_labview怎么用龙源期刊网http://www.qikan.com.cn基于LabVIEW的旋转倒立摆系统设计作者:白富斌董君浩侯丽鹏来源:《现代商贸工业》2016年第09期摘要:以LabVIEW为平台,结合PID算法,对旋转倒立摆系统设计进行设计研究。在倒立摆旋转过程中,通过编码器将判断位置与角度的相应电信号反馈给上位机,上位机通过运行程序计算并输出信号进而来控制摆杆的的角度、位置,使倒立摆的摆杆不会下垂。关键…

    2022年8月18日
    6
  • 前端vscode必备插件推荐(墙裂推荐)「建议收藏」

    前端vscode必备插件推荐(墙裂推荐)「建议收藏」前言:vscode是一款强大的前端编辑软件,有些人说ws(webstorm)更好用,但是vs重在轻量级啊!!!而且根据自己的开发习惯安装适合自己的插件后,用起来简直不要太舒服了好嘛!!!首先呢,我先推荐的就是最基础的语言包,没办法,英语水平太捞了哈哈哈,弄起来后就舒服多了,汉语yyds~《Chinese(Simplified)(简体中文)Language》注释工具《ColorfulComments》不同的注释符能带来很多高亮的显示快速找到css定义位置并小窗口展示

    2022年7月25日
    16
  • 图片切割系统_图片切片工具

    图片切割系统_图片切片工具上一阵子做过一个图片切割效果,得到很多人关注。其中有很多人向我询问如何做一个真正的图片切割(裁剪),这里需要声明一下:首先js是不能操作客户端文件的(除非特殊情况),所以图片的切割必须在后台处理,对于

    2022年8月1日
    6
  • spring+websocket整合(springMVC+spring+MyBatis即SSM框架和websocket技术的整合)

    spring+websocket整合(springMVC+spring+MyBatis即SSM框架和websocket技术的整合)纠结了两天的

    2022年7月11日
    35
  • 数据库隔离级别及原理

    数据库隔离级别及原理数据库的隔离级别是通过共享锁和排他锁实现的 锁又可以分为表锁 页锁 行锁数据库事务的隔离级别有 4 个 由低到高依次为 Readuncommit Readcommitte Repeatablere Serializable 这四个级别可以逐个解决脏读 不可重复读 幻读这几类问题 脏读 读到的不是最新的数据不可重复读 读到是是最新的数据 但是一个事务中如果多次读取 可能每次读到

    2026年3月16日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号