- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们正在为 ORACLE 11g 中的客户规划一个新系统。我已经在 Sql Server 领域工作了好几年了,并没有真正了解最新的 ORACLE 更新。
我想知道 ORACLE 是否已经添加了一个特殊功能,即数据库对象的某种逻辑“容器”,类似于 Sql Server 的 SCHEMA
。
尝试从开发 > 测试 > 实时推送时,尝试使用 Sql Server 等 ORACLE 模式最终会成为代码比较的灾难。
包有点类似,只是你不能将表放入包中(所以它们实际上只适用于逻辑代码分组)。
我知道的唯一其他选项是必须在对象名称前添加“架构”前缀的过时做法,即 RPT_
REPORTS、RPT_
参数、RPT_
日志、RPT_
用户、 RPT_
RUN_REPORT(),前缀RPT_
表示这些是与我们的报告引擎打交道的所有对象。编写这样的系统感觉就像我们从未离开过 8.3 文件命名时代。
到目前为止,是否有任何更清晰、更直接的方法可以在 ORACLE 中将相关对象逻辑分组在一起?
最佳答案
Oracle 数据库对象的逻辑容器就是模式。不知道你能得到多少“干净”和“直接”!你必须在这里进行范式转变。不要试图用 SQL Server 术语来思考,并强制采用类似于 Oracle 上的 SQL Server 的解决方案。熟悉 Oracle 的业务并从该角度解决您的问题。如果您知道自己在做什么,那么在 Oracle 中从开发推进到测试再到生产应该没有问题。
当您使用“过时的实践”等术语时,您似乎对 Oracle 感到有些不满。我建议您通过阅读一些内容来与 Oracle 非常丰富且强大的功能集交 friend ,因为您显然已经致力于 Oracle 的这个项目。特别值得一读 Tom Kyte 所著的《Effective Oracle By Design》。读完本文后,请查看同一作者的“专家 Oracle 数据库架构”,更深入地了解 Oracle 的工作原理。您有责任让您的客户知道如何使用您收到的工具。谁知道?您甚至可能开始喜欢它。将其视为您工具箱中的另一个工具。您并未与 SQL Server 结婚,并且使用 Oracle 也并非不忠;-)
编辑:
回答OP的问题:
我不知道为什么这是一个后勤问题。它们可以被认为是独立的数据库,但实际上它们并不是。不,您不需要为每个模式使用单独的数据文件。单个数据文件通常用于所有模式。
如果您想要一个“漂亮的、独立的数据库”(如 SQL Server),只需创建一个架构来存储所有对象。问题结束。您可以创建其他用户/模式,只是不要赋予他们创建对象的能力。
有一些工具可以比较对象和数据,如 PL/SQL Developer 中的比较。通常在 Oracle 中您想要比较模式,而不是整个数据库。我不知道为什么你想要有多个模式,每个模式都有自己的对象。是什么让你这么做?将您的对象(表、触发器、代码、 View 等)保存在一个架构中。
关于oracle - ORACLE 中的逻辑分组模式?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8039512/
当我尝试加载库 Raster 时,我收到如下错误: 错误:inDL(x, as.logic(local), as.logic(now), ...) 中的“raster”的包或命名空间加载失败:无法加载
当我尝试加载库 Raster 时,我收到如下错误: 错误:inDL(x, as.logic(local), as.logic(now), ...) 中的“raster”的包或命名空间加载失败:无法加载
望着help section about_Comparison_Operators of PowerShell我是这样理解的: PS C:\> $false,$false -eq $true PS C
我刚刚修改了旧代码,现在似乎没有任何效果。请您指导我哪里出错了。 一些不起作用的事情是: 以前,焦点始终停留在屏幕上唯一的输入字段上。 (现在不行了),代码中的 if else 条件也不起作用。 On
请帮我找到一个使用普通 'ol javascript 的解决方案(我无法使用外部框架)。此外,CSS :hover 选择器不适用于现实世界的实现。 注册事件发生的事情设置所有调用最后注册事件数组项。
我想创建一个软件来为残障 child 交通规划公交路线(及其最佳载客量)。 这些总线具有以下规范: m 个座位(最多 7 个 - 因为有司机和助理) o 轮椅“座位”(最多 4 个) 固定的最大负载量
有人能帮我吗?似乎我的 for 逻辑根本不起作用,因为它一直在上午 12:00 返回我的开始时间 这是我的代码 Sub forlogic() Dim i As Single Dim t
我正在尝试设置 OR两个切片器过滤器之间的逻辑。两个切片器来自相同的数据集。以下是更多详细信息: 我的源表: 带切片器的视觉效果: 我的目标是,如果我从切片器 1 和切片器 2 中选择任何值,我的视觉
我有以下 C 语句: int res = x & (x ^ y); 有没有办法做同样的事情,但每次只使用一次x和y? 例如: x | (~x & y) == x | y 最佳答案 是的,通过扩展 xo
我正在创建 Azure 逻辑应用程序以将新的 Sharepoint 文件添加到 Azure Blob。 Sharepoint 由我的公司运行,我使用我的凭据登录来为逻辑应用程序创建 Sharepoin
我有一个问题要求为给定函数合成最简单的乘积表达式总和。基本上,如果 AB == CD,则函数为 1,否则为 0,结果如下: (!A && !B && !C && !D) || (!A && B &&
我正在尝试确定是否可以在不溢出的情况下计算两个 32 位整数的总和,同时仅使用某些按位运算符和其他运算符。因此,如果整数 x 和 y 可以相加而不会溢出,则以下代码应返回 1,否则返回 0。 ((((
处理乍一看需要许多嵌套 if 语句的复杂业务逻辑的好方法是什么? 例子: 折扣券。可能: 1a) 超值折扣 1b) 百分比折扣 2a) 正常折扣 2b) 累进折扣 3a) 需要访问优惠券 3b) 不需
假设我有一个“numbers”对象数组,其中包含“startNo”整数和“endNo”整数。 数组中可以有多个“数字”,我想获取一个包含修改对象的新数组,该数组仅具有不重叠的范围。 例如:如果数组有:
我在这个问题上遇到了困难。我正在使用 JavaScript。 我有一个文本区域,用于检测 @ 输入并将其位置存储在数组中。 var input = "@a @b @c" //textarea var
默认 IN 使用 OR 基本逻辑。有没有办法在范围内使用 AND 基本逻辑。 例如下面的查询 SELECT ItemId,CategoryID FROM ItemCategories WHERE Ca
我想在您将鼠标悬停在网站图像上时添加叠加层。我在这里实现了这个,它工作正常http://jsfiddle.net/stujLbjh/ 这是js代码: var divs = document.query
这个问题在这里已经有了答案: Which is faster: x>2 是否比 x>>31 快?换句话说,sar x, 2 是否比 sar x, 31 快?我做了一些简单的测试,他们似乎有相同的速度
我有grails criteriaQuery,我在这里再次检查OR逻辑,就像这样一个状态变量: or { eq("status", Status.ONE) eq("status",
我有grails criteriaQuery,我在这里再次检查OR逻辑,就像这样一个状态变量: or { eq("status", Status.ONE) eq("status",
我是一名优秀的程序员,十分优秀!