热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

ArcSDE10.2.1forOracle12c的建库模式

前面我们已经介绍了怎么在Oracle12c环境下创建Geodatabase10.2.1,但是这些都是在默认环境下进行的建库,那么如果用户希望新创建一个PDB,然后再在新创建的PDB上创建ArcSDE地理数据库,而且用户希望再创建一个普通的SDE数据库用户该怎么操作呢?注意:以下

前面我们已经介绍了怎么在Oracle12c环境下创建Geodatabase10.2.1,但是这些都是在默认环境下进行的建库,那么如果用户希望新创建一个PDB,然后再在新创建的PDB上创建ArcSDE地理数据库,而且用户希望再创建一个普通的SDE数据库用户该怎么操作呢? 注意:以下

前面我们已经介绍了怎么在Oracle12c环境下创建Geodatabase10.2.1,但是这些都是在默认环境下进行的建库,那么如果用户希望新创建一个PDB,然后再在新创建的PDB上创建ArcSDE地理数据库,而且用户希望再创建一个普通的SDE数据库用户该怎么操作呢?

注意:以下操作都是在用户使用PDB基础上,鉴于PDB收费,如果用户使用非PDB的Oracle实例,那么在相关操作与Oracle11g版本基本一致。



用户可以不勾选Create as Container database。就不创建PDB了。



测试环境:

Linux 5.5、Oracle12.1.0.1 ( CDB:orcl PDB:pdborcl)、ArcGIS10.2.1


你知道吗?
Oracle 12c 数据库的多租户功能将单独收费,售价为 1.75万美元/处理器,而企业版 12c数据库的售价仍为 4.75 万美元/处理器。

1:创建一个新的PDB:pdbsde

创建一个新的PDB有多种创建方式,我们使用的方式是使用PDB的Seed创建PDB


我们需要连接CDB的SYS用户,使用CREATE PLUGGABLE DATABASE语句来创建PDB

SQL> CREATE PLUGGABLE DATABASE pdbsde ADMIN USER sdeadmin IDENTIFIED BY sdeadmin
  2  STORAGE (MAXSIZE 2G MAX_SHARED_TEMP_SIZE 100M) DEFAULT TABLESPACE pdbsde
DATAFILE '/home/oracle/app/oracle/oradata/orcl/pdbsde/pdbsde.dbf' SIZE 500M AUTOEXTEND ON
  3    4  PATH_PREFIX = '/home/oracle/app/oracle/oradata/orcl/pdbsde/'
  5  FILE_NAME_COnVERT= ('/home/oracle/app/oracle/oradata/orcl/pdbseed/',
  6  '/home/oracle/app/oracle/oradata/orcl/pdbsde/');


Pluggable database created.
相关的参数解释请参考:


--------------------------------------------------------------------------------------------

Blog: http://blog.csdn.net/linghe301
Weibo: http://www.weibo.com/linghe301
--------------------------------------------------------------------------------------------


创建好PDB之后,我们来查看一下PDB的状态信息,如下所示,新创建的PDBSDE是Mounted状态,我们需要手动打开,然后查看一下数据文件的变化。

SQL> select con_id,dbid,NAME,OPEN_MODE from v$pdbs;

    CON_ID       DBID NAME                           OPEN_MODE
---------- ---------- ------------------------------ ----------
         2 4062262812 PDB$SEED                       READ ONLY
         3 2266793495 PDBORCL                        READ WRITE
         4  323980054 PDBSDE                         MOUNTED

SQL> alter pluggable database pdbsde open;

Pluggable database altered.

SQL>  select name from v$datafile;

NAME
--------------------------------------------------------------------------------
/home/oracle/app/oracle/oradata/orcl/system01.dbf
/home/oracle/app/oracle/oradata/orcl/sysaux01.dbf
/home/oracle/app/oracle/oradata/orcl/undotbs01.dbf
/home/oracle/app/oracle/oradata/orcl/pdbseed/system01.dbf
/home/oracle/app/oracle/oradata/orcl/users01.dbf
/home/oracle/app/oracle/oradata/orcl/pdbseed/sysaux01.dbf
/home/oracle/app/oracle/oradata/orcl/pdborcl/system01.dbf
/home/oracle/app/oracle/oradata/orcl/pdborcl/sysaux01.dbf
/home/oracle/app/oracle/oradata/orcl/pdborcl/SAMPLE_SCHEMA_users01.dbf
/home/oracle/app/oracle/oradata/orcl/pdborcl/example01.dbf
/home/oracle/app/oracle/product/12.1.0/dbhome_1/dbs/sde01

NAME
--------------------------------------------------------------------------------
/home/oracle/app/oracle/oradata/orcl/esri.dbf
/home/oracle/app/oracle/oradata/orcl/pdborcl/esri.dbf
/home/oracle/app/oracle/oradata/orcl/pdborcl/esri2.dbf
/home/oracle/app/oracle/oradata/orcl/pdbsde/system01.dbf
/home/oracle/app/oracle/oradata/orcl/pdbsde/sysaux01.dbf
/home/oracle/app/oracle/oradata/orcl/pdbsde/pdbsde.dbf

17 rows selected.

SQL>

接下来,我们使用SYS用户连接PDBSDE,创建SDE的表空间数据问题(由于如果使用ArcGIS10.2.1 for Desktop的Create Enterprise Geodatabase创建的SDE表空间文件默认存储在/home/oracle/app/oracle/product/12.1.0/dbhome_1/dbs/sde01路径下,但是该文件并不能明确看出该文件是由CDB或者哪一个PDB创建的,所以建议用户手动创建SDE数据文件,并指定相关的PDB名称,如/home/oracle/app/oracle/oradata/ora/pdbsde/

SQL> conn sys/oracle@192.168.220.203/pdbsde as sysdba
Connected.
SQL> CREATE SMALLFILE TABLESPACE SDE DATAFILE '/home/oracle/app/oracle/oradata/orcl/pdbsde/sde.dbf' SIZE 1000M LOGGING EXTENT MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO DEFAULT NOCOMPRESS
  2  ;

Tablespace created.
创建之后,我们就可以使用创建地理数据库工具来创建存储在PDBSDE下的地理数据库

创建完毕之后,我们就可以使用sde用户进行连接了。

--------------------------------------------------------------------------------------------

Blog: http://blog.csdn.net/linghe301
Weibo: http://www.weibo.com/linghe301
--------------------------------------------------------------------------------------------


2:前面也提到了,用户希望创建自己业务数据的表空间以及相关用户,那么假设用户创建了ESRI表空间,以及所属该表空间的test2用户。

SQL> conn sys/oracle@192.168.220.203/pdbsde as sysdba
Connected.
SQL> CREATE SMALLFILE TABLESPACE SDE DATAFILE '/home/oracle/app/oracle/oradata/orcl/pdbsde/sde.dbf' SIZE 1000M LOGGING EXTENT MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO DEFAULT NOCOMPRESS
  2  ;

Tablespace created.

SQL>
SQL> CREATE SMALLFILE TABLESPACE ESRI DATAFILE '/home/oracle/app/oracle/oradata/orcl/pdbsde/esri.dbf' SIZE 100M LOGGING EXTENT MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO DEFAULT NOCOMPRESS;

Tablespace created.

表空间创建之后,我们就习惯的使用PL/SQL等Oracle客户端软件创建相关的数据库用户test2,赋予Connect和Resouce等角色。

但是,通过ArcCatalog连接test2用户,创建要素类系统提示如下错误:ORA-01950


我们查看一下Ora-01950错误

SQL> !oerr ora 01950
01950, 00000, "no privileges on tablespace '%s'"
// *Cause:  User does not have privileges to allocate an extent in the
//          specified tablespace.
// *Action: Grant the user the appropriate system privileges or grant the user
//          space resource on the tablespace.
错误提示,该用户没有对表空间ESRI分配Extent的权限,其实也就是没有赋予用户Quota权限。


Oracle 官网对quota的定义如下: A limit on a resource, such as a limit on the amount of database storage used by a database user. A database administrator can set tablespace quotas for each Oracle Database username。


quota是为了限制用户对表空间的使用,比如你限制用户test在tablespace SDE中的quota为10m,当用户test在tablespace SDE中的数据量达到10m后,无论你的tablespace SDE中有多少空间,test都无法再使用tablespace SDE了。


在Oracle11g以及以前版本,如果用户赋予resouce角色之后,系统会自动赋予对该用户所属默认表空间quota umlimited to表空间,但是Oracle12c之后,即使赋予resouce角色之后,系统是不会默认赋予quota权限了,需要用户手动赋予。


查看Oracle帮助也明确说明了该问题


http://docs.oracle.com/cd/E16655_01/network.121/e17607/release_changes.htm#DBSEG941

--------------------------------------------------------------------------------------------

Blog: http://blog.csdn.net/linghe301
Weibo: http://www.weibo.com/linghe301
--------------------------------------------------------------------------------------------


所以用户在创建新用户需要设置quota权限即可

方式一:

SQL> create user test2 identified by test2 DEFAULT TABLESPACE ESRI TEMPORARY TABLESPACE TEMP ACCOUNT UNLOCK  quota unlimited on esri cOntainer=current;

User created.

SQL> grant connect,resource to test2;

Grant succeeded.
方式二:
SQL> create user test2 identified by test2 DEFAULT TABLESPACE ESRI TEMPORARY TABLESPACE TEMP ACCOUNT UNLOCK   cOntainer=current;

User created.

SQL> grant connect,resource to test2;

Grant succeeded.
 
SQL> grant unlimited tablespace to test2;

Grant succeeded.
下面用户就可以使用test2用户来加载空间数据了



下面来看一下,各个CDB、PDB与用户的关系


从我们的测试环境可以看出,系统默认已经有一个CDB、PDBORCL,而且在PDBORCL里面创建了ArcSDE地理数据库,那么默认的SYS/SYSTEM用户是整个Oracle数据库的超级用户,它既可以操作CDB,又可以操作PDBORCL,而PDBORCL默认创建的SDE用户只能操作PDBORCL里面的SDE数据库,系统又新创建了一个PDBSDE,然后又创建了一个SDEADMIN的管理用户,默认的SDE用户和新创建的TEST2用户,那么这三个用户只能对PDBSDE进行操作,而不能管理PDBORCL。


其实Oracle12c的CDB和PDB可以类比CDB就是原来整个Oracle数据库,PDB就是数据库的一个实例,用户可以创建多个PDB,同样用户也可以在一个数据库中创建多个实例,但是每个实例都有自己的超级管理员,但是Oracle12c只需要一个CDB的管理员帐号就可以管理所有的PDB。

--------------------------------------------------------------------------------------------

Blog: http://blog.csdn.net/linghe301
Weibo: http://www.weibo.com/linghe301
--------------------------------------------------------------------------------------------



用户可以不勾选Create as Container database。就不创建PDB了。

推荐阅读
  • 作为软件工程专业的学生,我深知课堂上教师讲解速度之快,很多时候需要课后自行消化和巩固。因此,撰写这篇Java Web开发入门教程,旨在帮助初学者更好地理解和掌握基础知识。通过详细记录学习过程,希望能为更多像我一样在基础方面还有待提升的学员提供有益的参考。 ... [详细]
  • PHP自学必备:从零开始的准备工作与工具选择 ... [详细]
  • WebStorm 是一款强大的集成开发环境,支持多种现代 Web 开发技术,包括 Node.js、CoffeeScript、TypeScript、Dart、Jade、Sass、LESS 和 Stylus。它为开发者提供了丰富的功能和工具,帮助高效构建和调试复杂的 Node.js 应用程序。 ... [详细]
  • 数据库多表联合查询:内连接与外连接详解
    在数据库的多表查询中,内连接和外连接是两种常用的技术手段。内连接用于检索多个表中相互匹配的记录,即只有当两个表中的记录满足特定的连接条件时,这些记录才会被包含在查询结果中。相比之下,外连接则不仅返回匹配的记录,还可以选择性地返回不匹配的记录,具体取决于左外连接、右外连接或全外连接的选择。本文将详细解析这两种连接方式的使用场景及其语法结构,帮助读者更好地理解和应用多表查询技术。 ... [详细]
  • 在探讨 MySQL 正则表达式 REGEXP 的功能与应用之前,我们先通过一个小实验来对比 REGEXP 和 LIKE 的性能。通过具体的代码示例,我们将评估这两种查询方式的效率,以确定 REGEXP 是否值得深入研究。实验结果将为后续的详细解析提供基础。 ... [详细]
  • 阶段五 3. 微服务项目【学成在线】_第6天 页面部署与课程管理_15 课程计划查询SQL语句解析 ... [详细]
  • 初探性能优化:入门指南与实践技巧
    在编程领域,常有“尚未精通编码便急于优化”的声音。为了从性能优化的角度提升代码质量,本文将带领读者初步探索性能优化的基本概念与实践技巧。即使程序看似运行良好,数据处理效率仍有待提高,通过系统学习性能优化,能够帮助开发者编写更加高效、稳定的代码。文章不仅介绍了性能优化的基础知识,还提供了实用的调优方法和工具,帮助读者在实际项目中应用这些技术。 ... [详细]
  • 本文详细介绍了使用 Python 进行 MySQL 和 Redis 数据库操作的实战技巧。首先,针对 MySQL 数据库,通过 `pymysql` 模块展示了如何连接和操作数据库,包括建立连接、执行查询和更新等常见操作。接着,文章深入探讨了 Redis 的基本命令和高级功能,如键值存储、列表操作和事务处理。此外,还提供了多个实际案例,帮助读者更好地理解和应用这些技术。 ... [详细]
  • 使用SQL命令创建数据库及其语句解析
    使用 `CREATE DATABASE` 命令可以创建一个新的数据库,并指定其名称。该 SQL 语句用于初始化数据库结构,执行后将生成一个新的数据库实例,用于存储相关的数据对象和表。在本例中,通过执行 `CREATE DATABASE 课程管理1`,系统将创建一个名为“课程管理1”的数据库,以便后续的数据管理和操作。 ... [详细]
  • 如何高效地安装并配置 PostgreSQL 数据库系统?本文将详细介绍从下载到安装、配置环境变量、初始化数据库、以及优化性能的全过程,帮助读者快速掌握 PostgreSQL 的核心操作与最佳实践。文章还涵盖了常见问题的解决方案,确保用户在部署过程中能够顺利解决遇到的各种挑战。 ... [详细]
  • 在使用 SQL Server 时,连接故障是用户最常见的问题之一。通常,连接 SQL Server 的方法有两种:一种是通过 SQL Server 自带的客户端工具,例如 SQL Server Management Studio;另一种是通过第三方应用程序或开发工具进行连接。本文将详细分析导致连接故障的常见原因,并提供相应的解决策略,帮助用户有效排除连接问题。 ... [详细]
  • SSAS入门指南:基础知识与核心概念解析
    ### SSAS入门指南:基础知识与核心概念解析Analysis Services 是一种专为决策支持和商业智能(BI)解决方案设计的数据引擎。该引擎能够为报告和客户端应用提供高效的分析数据,并支持在多维数据模型中构建高性能的分析应用。通过其强大的数据处理能力和灵活的数据建模功能,Analysis Services 成为了现代 BI 系统的重要组成部分。 ... [详细]
  • 在使用SSH框架进行项目开发时,经常会遇到一些常见的问题。例如,在Spring配置文件中配置AOP事务声明后,进行单元测试时可能会出现“No Hibernate Session bound to thread”的错误。本文将详细探讨这一问题的原因,并提供有效的解决方案,帮助开发者顺利解决此类问题。 ... [详细]
  • 二十六、Java开发实战:PL/SQL轻松实现远程数据库连接
    通过 PL/SQL Developer 实现远程数据库连接的详细步骤如下:首先启动 PL/SQL Developer 软件,然后在登录界面中准确输入用户名和密码;接着在数据库连接配置中,按照 IP:Port/SID 的格式填写目标数据库的地址信息。此外,确保网络环境畅通无阻,并检查防火墙设置以避免连接失败。 ... [详细]
  • 在Node.js中调用MySQL存储过程`updateUser(p1, p2, @p3)`时,其中`@p3`为输出参数。若更新操作失败,则返回0;成功则返回1。本文将详细介绍如何正确获取存储过程的返回结果,并确保在实际应用中能够顺利执行。 ... [详细]
author-avatar
mobiledu2502884697
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有