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为数据库 对象的集合,为了区分各个集合,我们需要给这个集合起个名字,这些名字就是我们在企业管理器的方案下看到的许多类似用户名的节点,这些类似用户名的节点其 实就是一个schema,schema里面包含了各种对象如tables, views, sequences, stored procedures, synonyms, indexes, clusters, and database links。
  
  一个用户一般对应一个 schema,该用户的schema名等于用户名,并作为该用户缺省schema。这也就是我们在企业管理器的方案下看到schema 名都为数据库用户名的原因。Oracle数据库中不能新创建一个schema,要想创建一个schema,只能通过创建一个用户的方法解决(Oracle 中虽然有create schema语句,但是它并不是用来创建一个schema的),在创建一个用户的同时为这个用户创建一个与用户名同名的schem并作为该用户的缺省 shcema。即schema的个数同user的个数相同,而且schema名字同user名字一一 对应并且相同,所有我们可以称schema为user的别名,虽然这样说并不准确,但是更容易理解一些。
  
  一个用户有一个缺省的 schema,其schema名就等于用户名,当然一个用户还可以使用其他的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名。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle是一种关系型数据库管理系统,它使用表和视图来组织和存储数据。当我们创建一个新的用户时,我们可以为该用户创建一个新的模式(schema),以便该用户可以在该模式创建和管理自己的表、视图和其他数据库对象。 在Oracle,授权是授予用户执行特定操作的权限。要将一个模式授权给一个用户,我们可以使用GRANT语句。例如,要将模式名为“myschema”的模式授权给用户“myuser”,可以执行以下命令: GRANT ALL PRIVILEGES ON myschema TO myuser; 上述命令将授予用户“myuser”在模式“myschema执行所有操作的权限。这包括创建、修改和删除表、视图和其他对象的权限。 除了授予所有权限之外,我们还可以根据具体需求来授予特定的权限。例如,要授予用户“myuser”在模式“myschema只读访问的权限,可以执行以下命令: GRANT SELECT ON myschema TO myuser; 上述命令将授予用户“myuser”在模式“myschema执行SELECT操作的权限,但不允许用户修改或删除表或其他对象。 要撤销用户对模式的授权,我们可以使用REVOKE语句。例如,要撤销用户“myuser”对模式“myschema”的所有权限,可以执行以下命令: REVOKE ALL PRIVILEGES ON myschema FROM myuser; 上述命令将从用户“myuser”撤销在模式“myschema执行所有操作的权限。 通过这些授权和撤销命令,我们可以灵活地管理Oracle数据库的用户和模式之间的访问权限,以满足不同用户的需求和安全要求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值