BIEE入门(二)物理层的定义
使用BIEE的第一步是使用admintool去建立一个多维数据模型,而建立多维数据模型的第一步则是建立物理层,请注意因为BIEE本身并不存 储数据,所以所谓BIEE物理层的意义是需要在BIEE里建立各个源系统的描述:
· 如源系统的类型(各种关系数据库或各种多维数据库)
· 源系统的连接方式(指定所对应的源系统的连接信息,如用户名,密码,端口等)
· 以及导入源系统的数据的定义(源系统里表的结构,主外键关系等)
定义物理层的方式是从file-》import。。。-》from database然后通过向导选择正确的数据库类型并输入连接信息。在最简单的时候,这样就可以完成整个物理层的定义了,接着可以继续进行逻辑层的定义工 作,但是其实物理层还是有一些额外的配置值得交代。
物理层的额外配置
数据源额外的物理层配置的第一个地方就是关于数据源的属性,因为BIEE被设计用于连 接各种各样的数据源,而每个数据源的特性都是不一样的,比如哪怕同样是关系数据库,Oracle和DB2的很多特性就不一样,为了能够充分发挥一个特定的 数据源的能力,BIEE的物理层数据源里允许人为配置数据源所支持的各种额外特性,如下图: 窗体顶端 窗体底端通过这样的配置,BI Server将可以充分使用不同数据源的各种能力,生产数据源所支持的特性的SQL来提高处理效率,但是对于配置这些属性还是要小心,因为如果配置了数据 源不能支持的属性,则在针对该数据源查询的时候将会返回错误!
连接池物理层第二个需要说明的是:在import的时候,源系统的大部分数据结构和主外键信 息都会自动地输入到Repository里,而物理层通过一个连接池的定义来和源系统连接,BI Server使用连接池的定义和源系统进行连接,这个“连接池”和一般的应用服务器的连接池定义有相似之处,除了同样可以:
· 定义最大连接数
· 连接idle时间
· 交易隔离类型(如脏读,序列化等)
还有一个有意思的地方是,可以定义连接数据源所需要执行的额外脚本,或者在执行查询之前和查询之后都可以定义需要额外执 行的SQL语句,如下图(点击查看大图): 窗体顶端 窗体底端
这样就可以在每次查询之前或之后去执行一些特定的SQL语句,从而提供了更多的可能性。
物理层的表物理层的第三个需要说明的地方是关于物理层表的 定义:物理层表的定义对应着数据源的真正的表,除了可以把源系统的表的各种定义属性导入到物理层,BIEE也提供了在物理层定义源系统所不存在的各种关系 的重新定义,如定义源系统所不存在的主外键关系来为星型模型做准备,还有一个特性是直接和BI Server的缓冲区直接相关,就是BI Server可以定义缓冲区,当第一次查询的时候数据可以缓冲中BI Server的缓冲区里,第二次查询将不再把查询发到数据源,而是可以直接使用缓冲区的数据,这样将能够有效地减少对于数据源的查询压力和提高查询性能, 特别是对一些更新没这么快的数据源而言是一个非常好的选择,如下图: 窗体顶端 窗体底端
从这里你可以看到,其实BIEE的设计有很多地方还是非常好的!另外,也可以定义一个表使用SQL或者存储过程来生成,而不一定非要是一个实际存 在的物理表。最后需要对物理层进行说明的是关于表和表之间的关系: 我们都知道为了构建星型模型,在事实表和维表之间存在主外键关系是必要的,所以首先需要检查我们需要分析的源系统里的维表是否有主键(如果没有可以在物 理层里定义),然后还要通过物理关系图定义他们之间的外键关系来构建一个星型模型,如下图: 窗体顶端 窗体底端这个定义主要是通过一个类似画板的东西上进行划线来形成,这样就完成了物理层的定义。
BIEE入门(二)物理层的定义的更多相关文章
- Swift语法基础入门二(数组, 字典, 字符串)
Swift语法基础入门二(数组, 字典, 字符串) 数组(有序数据的集) *格式 : [] / Int / Array() let 不可变数组 var 可变数组 注意: 不需要改变集合的时候创建不可变 ...
- Thinkphp入门 二 —空操作、空模块、模块分组、前置操作、后置操作、跨模块调用(46)
原文:Thinkphp入门 二 -空操作.空模块.模块分组.前置操作.后置操作.跨模块调用(46) [空操作处理] 看下列图: 实际情况:我们的User控制器没有hello()这个方法 一个对象去访问 ...
- css入门二-常用样式
css入门二-常用样式总结 基本标签样式 背景色background-color 高度height; 宽度width; 边框对齐以及详细设定举例 width/*宽度*/: 80%; height/*高 ...
- IM开发者的零基础通信技术入门(二):通信交换技术的百年发展史(下)
1.系列文章引言 1.1 适合谁来阅读? 本系列文章尽量使用最浅显易懂的文字.图片来组织内容,力求通信技术零基础的人群也能看懂.但个人建议,至少稍微了解过网络通信方面的知识后再看,会更有收获.如果您大 ...
- C#中的特性 (Attribute) 入门 (二)
C#中的特性 (Attribute) 入门 (二) 接下来我们要自己定义我们自己的特性,通过我们自己定义的特性来描述我们的代码. 自定义特性 所有的自定义特性都应该继承或者间接的继承自Attribut ...
- Netty入门二:开发第一个Netty应用程序
Netty入门二:开发第一个Netty应用程序 时间 2014-05-07 18:25:43 CSDN博客 原文 http://blog.csdn.net/suifeng3051/article/ ...
- C#基础入门 二
C#基础入门 二 循环语句 与C语言中用法相同. continue:结束本次循环(continue)后面的代码不再执行,进入下次循环(通常与if连用). 数组 一维数组定义:int[] intArra ...
- BIEE入门(一)架构
BIEE作为Oracle的新的商业智能平台企业版,起源于Oracle所收购的Siebel公司,BIEE原来叫做Siebel Analytic,但是Siebel也不是它的发明者,它是Siebel在200 ...
- MySQL概述及入门(二)
MySql概述及入门(二) MySQL架构 逻辑架构图: 执行流程图: MySQL的存储引擎 查询数据库支持的存储引擎 执行: show engines: 多存储引擎是mysql有别于其他数据库的一大 ...
随机推荐
- JavaScript 调用 Windows 的打印 代码
JavaScript 调用 Windows 的打印 代码 2009-02-24 10:36 <%@ Page Language="C#" AutoEventWireup=&q ...
- window环境下安装Python2和Python3
一. python 安装 1. 下载安装包 https://www.python.org/ftp/python/2.7.14/python-2.7.14.amd64.msi # 2.7安装包 htt ...
- 江西理工大学南昌校区排名赛 E: 单身狗的种树游戏
题目描述 萌樱花是一只单身狗. 萌樱花今天决定种树,于是他来到了自己家的后院. 萌樱花的后院有n个树坑,所有树坑排列在一行上,每一个树坑都可以种一棵树,相邻树坑间的距离为1,现在所有的树坑都是空着的. ...
- 江西理工大学南昌校区排名赛 C: 单身狗的地图游戏
题目描述 萌樱花是一只单身狗. 萌樱花今天决定去喜欢的学妹家玩,但他不记得路,于是他拿出有n个点的完全图,选取了k条不同的路. 完全图:n 个点的图中任意两个点之间都有一条边相连,所以有 n*(n-1 ...
- 获取url路径的正则
package unit; import java.util.regex.Matcher; import java.util.regex.Pattern; public class Util { // ...
- BeautifulSoup库应用实例
获取博客园本人的积分排名数据: 1. 抓包获取积分排名数据返回接口:http://www.cnblogs.com/belle-ls/mvc/blog/sidecolumn.aspx?blogApp=b ...
- Vue添加新的响应式属性
vm.userProfile = Object.assign({}, vm.userProfile, { age: , favoriteColor: 'Vue Green' })
- WPF中嵌入Skyline提供的COM组件填坑
网上有很多关于在WPF中使用的Skyline提供的COM组件的教程,但大都雷同一律,其中很多的细节均为涉及,本文意在在其原基础上进行一些细节的补充. 工具:Visual Studio 2017 1. ...
- js 用简单案例举模态对话框弹出
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- 从Linux服务器下载文件到本地
通过安装xshell,连接服务器,通过以下命令可以方便的将服务器的文件下载到本地 #下载一个文件 sz filename #下载多个文件 sz filename1 filename2 #下载dir目录 ...