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/119272.html原文链接:https://javaforall.net

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


相关推荐

  • IDEA集成git和使用步骤

    IDEA集成git和使用步骤一 IDEA 集成 git 方法 nbsp nbsp nbsp 首先 idea 集成 git 我们需要先下载一个小软件 gitbash nbsp 地址 https git scm com downloads nbsp 下载好了之后直接下一步下一步傻瓜试安装 安装好后回在你指定的文件夹下有个 git 文件夹 文件结构如下 当然如果你对 git 命令比较熟悉 用这个软件就可以实现所有的 git 操作了 下面我们来集成进 IDEA 开发工具 打开 I

    2026年3月20日
    5
  • C#中IntPtr类型

    1.C#中的IntPtr类型被称之为“平台特定的整数类型”,用于本机资源,例如窗口句柄。2.资源的大小取决于使用的硬件和操作系统,即此类型的实例在32位硬件和操作系统中将是32位,在64位硬件和操作系统中将是64位;但其大小总是足以包含系统的指针(因此也可以包含资源的名称)。3.在调用API函数时,类似含有窗口句柄参数(HANDLE)的原型函数,应显示地声明为IntPtr类型。4.In…

    2022年4月4日
    197
  • Java与C++的优劣:谁更胜一筹?

    Java与C++的优劣:谁更胜一筹?1.基础介绍Java与C++都拥有相当长的历史,且语法相当类似,并被众多业界巨头所采用。事实上,Java本来就是从C++衍生出来的。不过尽管相似,二者之间仍然存在显著区别。很多人都说会C++就能会快掌握Jave。C++是不好学,但是我告诉你java也不好学。C++难是难在语言本身,java难是难在各种框架和库。你单纯学个java语法,你什么玩意也做不了,java的东西都在java之外。

    2022年7月7日
    36
  • linux select函数详解

    linux select函数详解在 Linux 中 我们可以使用 select 函数实现 I O 端口的复用 传递给 select 函数的参数会告诉内核 nbsp nbsp nbsp nbsp nbsp 我们所关心的文件描述符 nbsp nbsp nbsp nbsp nbsp 对每个描述符 我们所关心的状态 我们是要想从一个文件描述符中读或者写 还是关注一个描述符中是否出现异常 nbsp nbsp nbsp nbsp nbsp 我们要等待多长时间 我们可以等待无限长的时间 等待固定的一段时间 或者根本就不等待

    2026年3月18日
    2
  • 扒一扒使用boostrap-fileinput上传插件遇到的坑,Bootstrap-fileinput上传插件的使用详解,「建议收藏」

    扒一扒使用boostrap-fileinput上传插件遇到的坑,Bootstrap-fileinput上传插件的使用详解,「建议收藏」由于公司项目的需求,需要实现动植物名录的添加,包括姓名等信息和图片等,需要使用bootstrap-fileinput的上传插件,在提交添加界面表单数据的同时上传一张或者多张图片,并将上传的图片保存到本地磁盘中(本文是f:盘的目录下),在在实现的时候,不适用bootstrap-fileinput上传插件本身的上传按钮(因为本身的按钮只能上传图片),需要点击提交,将表单的其他信息和图片一起提交到后台。

    2022年6月7日
    152
  • 小树剪发网1114_aow把抓

    小树剪发网1114_aow把抓乔治拿来一组等长的木棒,将它们随机地砍断,使得每一节木棍的长度都不超过 50 个长度单位。然后他又想把这些木棍恢复到为裁截前的状态,但忘记了初始时有多少木棒以及木棒的初始长度。请你设计一个程序,帮助乔治计算木棒的可能最小长度。每一节木棍的长度都用大于零的整数表示。输入格式输入包含多组数据,每组数据包括两行。第一行是一个不超过 64 的整数,表示砍断之后共有多少节木棍。第二行是截断以后,所得到的各节木棍的长度。在最后一组数据之后,是一个零。输出格式为每组数据,分别输出原始木棒的可能最小长度

    2022年8月8日
    9

发表回复

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

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