在做Oracle数据库实验时都会用到一些示例SCHEMA如:HR、OE、SH等,在Oracle11g版本时在DBCA时直接勾选Sample Schemas就可以安装这些示例SCHEMA,如下图:
但到了Oracle12.2 版本,也有一个示例Schemas选项卡如下图所示:
但是数据库安装完成后却还是没有这些示例SCHEMA,到底是怎么回事呢?我们来查一下官方文档:
Starting with Oracle Database 12c Release 2, the latest version of the sample schema scripts are available on GitHub at https://github.com/oracle/db-sample-schemas/releases/latest.
During a complete installation of Oracle Database, the HR schema can be installed either manually or automatically when creating a database using the dbca
option. All the other sample schemas must be installed manually via the scripts available on GitHub.
从上面的官方文档中我们可以看到从Oracle12.2版本开始,示例Schemas的脚本被放到了GitHub上,在DBCA安装时只会安装hr示例Schema。从文档中给出的指定地址下载示例Schema安装脚本:
从README.txt文档中找到安装方法,开始安装:
sys@ORA12C>@mksamplespecify password for SYSTEM as parameter 1:Enter value for 1: 123456specify password for SYS as parameter 2:Enter value for 2: 123456specify password for HR as parameter 3:Enter value for 3: hrspecify password for OE as parameter 4:Enter value for 4: oespecify password for PM as parameter 5:Enter value for 5: pmspecify password for IX as parameter 6:Enter value for 6: ixspecify password for SH as parameter 7:Enter value for 7: shspecify password for BI as parameter 8:Enter value for 8: bispecify default tablespace as parameter 9:Enter value for 9: usersspecify temporary tablespace as parameter 10:Enter value for 10: tempspecify log file directory (including trailing delimiter) as parameter 11:Enter value for 11: /home/oracle/dbcaspecify connect string as parameter 12:Enter value for 12: localhost:1521/ora12cSample Schemas are being created ...mkdir: cannot create directory ‘/home/oracle/dbca’: File existsConnected.DROP USER hr CASCADE *ERROR at line 1:ORA-01918: user ‘HR‘ does not existDROP USER oe CASCADE *ERROR at line 1:ORA-01918: user ‘OE‘ does not existDROP USER pm CASCADE *ERROR at line 1:ORA-01918: user ‘PM‘ does not existDROP USER ix CASCADE *ERROR at line 1:ORA-01918: user ‘IX‘ does not existDROP USER sh CASCADE *ERROR at line 1:ORA-01918: user ‘SH‘ does not existDROP USER bi CASCADE *ERROR at line 1:ORA-01918: user ‘BI‘ does not existConnected.SP2-0310: unable to open file "__SUB__CWD__/human_resources/hr_main.sql"Connected.SP2-0310: unable to open file "__SUB__CWD__/order_entry/oe_main.sql"Connected.SP2-0310: unable to open file "__SUB__CWD__/product_media/pm_main.sql"Connected.SP2-0310: unable to open file "__SUB__CWD__/info_exchange/ix_main.sql"Connected.SP2-0310: unable to open file "__SUB__CWD__/sales_history/sh_main.sql"Connected.SP2-0310: unable to open file "__SUB__CWD__/bus_intelligence/bi_main.sql"Connected.not spooling currentlySP2-0310: unable to open file "__SUB__CWD__/mkverify.sql"
从上面看到输出报错,没有安装成功。报错的是“__SUB__CWD__”没有找到,打开mksample.sql文件,确实有这个变量,但不知道在哪里声明的。
重新查看README.md文档看到需要把“__SUB__CWD__”这个变量替换为当前路径,还给出了命令:
[oracle@rhel7 db-sample-schemas-12.2.0.1]$ perl -p -i.bak -e ‘s#__SUB__CWD__#‘$(pwd)‘#g‘ *.sql */*.sql */*.dat
执行完上面的脚本后重新安装示例Schema:
sys@ORA12C>@mksample 123456 123456 hr oe pm ix sh bi users temp /home/oracle/dbca/ 192.168.56.22:1521/ora12c
最终安装成功:
system@ORA12C>select username,created from dba_users where created>sysdate-1;USERNAME CREATED------------------------------ -----------------OE 20170816 23:32:22SH 20170816 23:34:25PM 20170816 23:33:13IX 20170816 23:34:12BI 20170816 23:36:20HR 20170816 23:32:07
参考:http://docs.oracle.com/database/122/COMSC/installing-sample-schemas.htm#COMSC-GUID-B0BEE222-D8B0-4B68-B359-DEA153956EF6
本文出自 “DBA Fighting!” 博客,请务必保留此出处http://hbxztc.blog.51cto.com/1587495/1956932
Oracle 12.2安装示例schema
标签:oracle 12.2 示例 schema
小编还为您整理了以下内容,可能对您也有帮助:
oracle中schema指的是什么
官方文档中关于schema是这样解释的:
“A schema is a collection of database objects. A schema is owned by a database user and has the same name as that user. Schema objects are the logical structures that directly refer to the database's data. Schema objects include structures like tables, views, and indexes.(There is no relationship between a tablespace and a schema. Objects in the same schema can be in different tablespaces, and a tablespace can hold objects from different schemas.)”
官方文档里面说得比较明白,schema是数据对象的集合,包括像表、视图、索引、同义词等等都可以说是schema的对象。
下面通过具体的例子来加深对user和schema两者区别的认识:
第一步,以sys用户登陆SQL并建立普通用户storm和penguin:
$ sqlplus / as sysdba
SQL> create user storm identified by storm;
User created.
SQL> create user penguin identified by penguin;
User created.
第二步,赋予一些基本的权限给新建的用户storm和penguin:
SQL> grant connect,create table,resource to storm,penguin;
Grant succeeded.
第三步,以storm用户登陆,创建一张表并插入数据:
SQL> conn storm/storm
Connected.
SQL> create table t (id int);
Table created.
SQL> insert into t values(1);
1 row created.
SQL> commit;
Commit complete.
第四步,以penguin用户登陆,看能否查询storm用户所建表里面的数据:
SQL> conn penguin/penguin
Connected.
SQL> select table_name from user_tables;
no rows selected
SQL> show user;
USER is "PENGUIN"
SQL> select * from storm.t;
select * from storm.t
*
ERROR at line 1:
ORA-00942: table or view does not exist
从以上结果可以看出,用户 penguin无法查看用户storm所建表里面的内容,甚至被告知没有这张表。
第五步,修改当前schema为storm,并继续查询:
SQL> alter session set current_schema=storm;
Session altered.
SQL> show user;
USER is "PENGUIN"
SQL> select * from storm.t;
select * from storm.t
*
ERROR at line 1:
ORA-00942: table or view does not exist
仍然不能查看。
第六步,以storm用户登陆,赋予penguin用户查看t表的权限:
SQL> conn storm/storm
Connected.
SQL> grant select on t to penguin;
Grant succeeded.
第七步,以penguin用户登陆,查看storm用户的t表:
SQL> conn penguin/penguin
Connected.
SQL> select * from storm.t;
ID
----------
1.更简单的,将当前schema更改为storm,可以简化查询过程:
SQL> alter session set current_schema=storm;
Session altered.
SQL> select * from t;
ID
----------
1.oracle中schema指的是什么
schema是一个逻辑概念,逻辑上把相关的所有对象(表、视图、索引,过程、包等)组织成一个集体。一般来说schema的名称和负责这个schema的用户名称是一致的。
在这里给你举个例子,说明schema和用户名、以及用户下面的表、索引的关系。
一个楼房相当于一个数据库
一个楼房内有2家住户,用户A,用户B。
当用户A进入自己的屋子(schema)后,就可以再自己的屋子里添加桌子(表),椅子(视图),沙发(索引)等。
当然用户B也可以在自己的屋子(schema)里添加不一样的桌子,椅子,沙发。
那么我们知道了A用户和B用户的屋子(schema)是不同的,所以一般我们会直接说A用户或者B用户,这样就能区别他们不同的桌子和椅子,但是严格来说,我们应该说A用户的屋子(schema)和B用户的屋子(schema)不一样。所以说这里面我们一般就说用户A,其实就直接代表了A这个schema。
oracle schema是什么意思
Schema是Oracle中一个重要的概念,很容易跟User概念混淆。从下面多个角度来介绍:
1、首先来看一下原始的英文定义:
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.
2、从定义中可知Schema为数据库对象的集合,为了区分各个集合,认为的给这个集合起个名字,也就是通常在企业管理器的方案下看到的许多类似用户名的节点,节点也就是一个Schema,其包含了各种数据对象:如tables,
views, sequences, stored proceres, synonyms, indexes, clusters, and database
links。
3、Oracle里Schema几乎和user/用户是通用的。Schema是指一组数据库Object
(比如:表,视图,包,序列,等等),而这些Object是属于用户的,
属于一个用户的所有Object就叫Schema。
4、User即Oracle中的用户,是控制权限的,和所有系统的中用户概念类似,用户所持有的是系统的权限及资源;而Schema所涵盖的是各种对象,它包含了表、函数、包等等对象的“所在地”,并不包括对他们的权限控制。
5、举例说明如下:
一个房子里面放满了家具,对这些家具有支配权的是房子的主人(User),而不是房子(Schema)。 你可以也是一个房子的主人(User),拥有自己的房子(Schema)。可以通过alter session的方式进入别人的房子。 这个时候,你可以看到别人房子里的家具(desc)。 如果你没有特别指定的话,你所做的操作都是针对你当前所在房子中的东西。
至于你是否有权限使用(select)、搬动(update)或者拿走(delete)这些家具就看这个房子的主人有没有给你这样的权限了,或者你是整个大厦(DB)的老大(DBA)。
oracle中schema指的是什么
模式是数据库对象的集合。模式对象是数据库数据的逻辑结构。(把数据库对象用模式分开成不同的逻辑结构)。
oracle11g及以前版本中 模式(schema) 和用户是一个概念(12c还没有搞明白)。
所以:scott.table1中scott 是模式名,也是用户名。
模式,应该是一组对象的集合,比如表、视图、存储过程。
角色,是一组权限的集合。可以把角色,授权给用户。
在最新的数据库结构中(比如sqlserver2008),用户和模式是分离的。
可以把模式,即一组对象 指定给用户。