看来有的人还是对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名。

oracle中schema指的是什么?相关推荐

  1. 转: oracle中schema指的是什么?

    看来有的人还是对schema的真正含义不太理解,现在我再次整理了一下,希望对大家有所帮助. 我们先来看一下他们的定义: A schema is a collection of database obj ...

  2. oracle中schema是什么,ORACLE中的两个概念:user和schema的区别和联系

    今天重读ORACLE官方文档<concepts>,读到schema的基本概念,对它的理解更进一层, 官方文档中关于schema是这样解释的: "A schema is a col ...

  3. oracle中字典指的是什么,ORACLE数据库中什么是数据字典及作用

    Oracle数据库一个最重要的部分就是数据字典,是只读类型的表的集合,提供数据库的信息.一个数据字典包括:    数据库对象所有的框架对象的定义[表.视图.索引.群集.同义词.序列.过程.函数.包.触 ...

  4. oracle中pga指什么,oracle学习SGA跟PGA理解

    SGA:SystemGlobal Area是OracleInstance的基本组成部分,在实例启动时分配;系统全局域SGA主要由三部分构成:数据库缓冲区.日志缓冲区.共享池,还可能包含:大池,JAVA ...

  5. oracle中pga指什么,oracle中pga内存分配原则

    pga_aggregate_target 通常缩写为P_A_T,该参数同时限制全局pga分配和私有工作区内存分配 在oracle9i以及10gr1中,单个sql操作内存使用存在如下限制: 对于串行操作 ...

  6. 分组函数group by和Oracle中分析函数partition by的用法以及区别

    今天有个同事给我打电话问我题目列出的这个问题,在日常开发中,确实它们俩都是与分组有关的,但是需要注意的是一个是分组函数另一个是分析函数,讲解用到的表就以Oracle中schema的scott的EMP表 ...

  7. 数据库中Schema(模式)概念相关

    数据库中Schema有两种含义,一种是概念上的Schema,指的是一组DDL语句集,该语句集完整地描述了数据库的结构.还有一种是物理上的 Schema,指的是数据库中的一个名字空间,它包含一组表.视图 ...

  8. ORACLE中的两个概念:user和schema的区别和联系

    http://oracle.chinaitlab.com/induction/835839.html 今天重读ORACLE官方文档<concepts>,读到schema的基本概念,对它的理 ...

  9. url oracle default schema,oracle @Table中使用schema时insert报错

    第一部分 测试情况如下: maven修改 com.alibaba druid 1.1.10 实体类 @Table(name = "dpcenter.xeuser") public ...

最新文章

  1. 数据结构与算法 / 分治算法
  2. vue 启动时卡死_十分钟浅入Vue 原理
  3. C 标准库 limits.h
  4. java json 修改字段_我们如何使用Java中的Jackson来更改JSON中的字段名称?
  5. python js返回 json_如何使用 Python 得到网页返回正确的 Json 数据
  6. Trufun Kant Studio 2008面向VS.NET的开发应用
  7. 基于腾讯AI Lab词向量进行未知词、短语向量补齐与域内相似词搜索
  8. html css底部弧度,CSS实现底部弧度效果
  9. 《我是一只IT小小鸟》
  10. c语言的按位取反运算符
  11. html如何添加微信好友,如何加微信好友,微信加人小妙招
  12. Oracle数据库限制ip访问
  13. 爬取豆瓣电影排行榜top250最新教程!经典爬虫案例
  14. java pfx_java读取pfx或P12格式的个人交换库公私钥
  15. C语言strtok()函数:字符串分割
  16. 不懂就要问!流量卡拒收对个人会有影响吗?
  17. Web前端开发框架推荐
  18. 股票交易接口开发原理是什么?
  19. AcWing 1293. 夏洛克和他的女朋友(思维 欧拉筛 图论)
  20. 打印输入的字符串(C语言)

热门文章

  1. oracle_sid只能有一个吗_第一次考教资!这些问题你都了解了吗?
  2. linux怎么切换为oracle用户权限,linux肿么给oracle中用户权限
  3. java 日期函数转换_java 日期函数转换
  4. c语言无法打开源文件xx.h,VS2015 + Qt5.9.2开发中无法打开源文件“ui_*.h” 和 error MSB6006: “cmd.exe”已退出,代码为 3之解决办法。...
  5. Android开发第二次课 布局方式
  6. IETF:名词历史简介互联网精神的典范
  7. springboot问题Description Resource Path Location Type Java compiler level does not match the version o
  8. python实现轨迹回放供应_运动轨迹回放 百度地图api示例源码
  9. ES6基础4(数据结构)-学习笔记
  10. 平衡二叉树 构造方法