Oracle数据库模型(OLAP/OLTP)
数据库模型
选择数据库模型:
- 联机事务处理OLTP(on-line transaction processing)
- OLTP是传统的关系数据库的主要应用,基本的、日常的事务处理。例如银行交易。
- OLTP系统强调数据库内存效率,强调内存各种指标的命中率,强调绑定变量、并发操作。
- 联机分析处理OLAP(on-line analytical processing)
- OLAP是数据仓库系统的主要应用,支持复杂的分析操作,侧重决策支持,并且提供直观易懂的查询结果。
- OLAP系统则强调数据分析,强调SQL执行市场,强调磁盘I/O,强调分区等。
|
OLTP |
OLAP |
|
|
用户 |
操作人员,低层管理人员 |
决策人员,高级管理人员 |
|
功能 |
日常操作处理 |
分析决策 |
|
DB 设计 |
面向应用 |
面向主题 |
|
数据 |
最新的,细节的,二维的,分立的 |
历史的,聚集的,多维的,集成的 |
|
存取规模 |
读/写数条(甚至数百条)记录 |
读上百万(甚至上亿)条记录 |
|
操作频度 |
非常频繁(以秒计) |
比较稀松(以小时甚至以周计) |
|
工作单位 |
严格的事务 |
复杂的查询 |
|
用户数 |
数百个-数千万个 |
数个-数百个 |
|
DB 大小 |
100MB-GB |
100GB-TB |
- 数据库名、实例名、ORACLE_SID的区别
实例名instance_name、ORACLE_SID与数据库及操作系统之间的关系
(ORACLE_SID)
OS<----------------> ORACLE 数据库 <--------(Instance_name(实例名))
|
数据库名(db_name) |
实例名(instance_name) |
ORACLE_SID(环境变量) |
|
数据库名是用于区分数据的内部标识,示以二进制方式存储在数据库控制文件中的参数. |
数据库实例名用于和操作系统之间的联系,用于对外部连接时使用. 在操作系统中要取的和数据库之间的交互,必须使用数据库实例名. |
在实际中,数据库实例名的描述有时使用实例名instance_name参数,有时使用ORACLE_SID参数. |
|
在数据安装或创建后不得修改. |
在数据库安装或创建数据库后,实例名可以被修改. |
instance_name参数是ORACLE数据库的参数,此参数可以在参数文件中查到; ORACLE_SID参数是操作系统环境变量. |
|
该参数被写入数据库参数文件pfile中 |
该实例名被写入数据库参数文件pfile中. |
|
|
db_name="orcl" #(不允许修改) db_domain=dbcenter.toys.com instance_name=orcl service_names=orcl.dbcenter.toys.com control_file=(............... |
db_name="orcl" #(不允许修改) db_domain=dbcenter.toys.com instance_name=orcl #(可以修改,可以与db_name相同也可不同) service_names=orcl.dbcenter.toys.com control_file=(............... ......... |
操作系统环境变量ORACLE_SID用于和操作系统交互.操作系统想要得到实例名,就必须使用ORACLE_SID. 在数据库安装之后,ORACLE_SID用于定义数据库参数文件的名称. $ORACLE_BASE/admin/DB_NAME/pfile/init$ORACLE_SID.ora 定义方法:export ORACLE_SID=orcl 可以用[oracle@Datacent]$ . oraenv 来切换不同的ORACLE_SID来通过操作系统来启动不同的实例(instance) |
- 你想用数据库做什么?
– OLAP---- 在线分析
• I/O,并行,动态采样,优化器......
– OLTP---- 在线交易
• 并发,内存,变量绑定,优化器......
- OLAP 相关的参数
- parallel_min_servers
并行行为控制
- db_file_multiblock_read_count
控制数据库怎么从磁盘上读取数据块,一次从磁盘上读取多少个数据块?一次读的数据块越多,IO次数就越少.
- optimizer_dynamic_sampling
动态采样
- sga_target(OLAP可以设置小一点)
- pga_aggregate_target
- optimizer_mode
- OLTP 相关的参数
- cursor_sharing
绑定变量,将差不多的sql语句,使用变量值替换不一样的值
- sga_target
内存(OLTP要设置大一点,尽量将数据放在内存中)
- Sessions
会话数
- pga_aggregate_target
每一个会话所占用的内存
- shared_pool_size
共享池,可存放sql语句的空间
Oracle数据库模型(OLAP/OLTP)的更多相关文章
- Oracle分析函数-OLAP函数总结
ORACLE OLAP 函数 最近这个东东用得特别多,总结了一下 . 语法: FUNCTION_NAME(,,...) OVER() OLAP函数语法四个部分: 1.function本身 用于 ...
- CORE EF生成ORACLE数据库模型报错问题记录
需求:最近在新开发一套在LINUX运行的API接口,需要用到net core api框架以及oracle数据库,首先需要解决的就是连接数据库问题,由于是DBFirst 加上之前很多老表不规范,导致了c ...
- Parallel Database for OLTP and OLAP
Parallel Database for OLTP and OLAP Just asurvey article on materials on parallel database products ...
- 细说 OLAP 与 OLTP
OLAP (Online analytical processing)[联机分析处理] 起源 数据库概念最初源于1962年Kenneth Iverson发表的名为"A Programming ...
- OLAP vs OLTP: what makes the difference
OLAP vs OLTP: what makes the difference OLPT and OLAP are complementingtechnologies. You can't live ...
- Oracle设计规范!
Oracle设计规范! 一哥们整理的Oracle的设计规范,相当的不错,贴这以备后续之需! 目录 1.数据库模型设计方法规范 1.1.数据建模原则性规范 1.2.实体型之间关系认定规范 1.3.范式化 ...
- Oracle并行执行特性应用初探
1. 序 在历史数据转出测试过程中,通过不断的优化,包括SQL调整和数据库调整,从AWR中看到,基本上难以进行更多的性能提升,于是准备试试并行执行的特性,从这个任务的特点来分析,也比较适合采 ...
- Oracle 11g数据库的创建
由于是自己自学Oracle,如果有问题,请大家指出,谢谢! Oracle提供了DBCA来创建数据库,对于初学者来说使用DBCA创建数据库简化了很多工作和设置,直接在交互界面即可实现所有的功能. 然而对 ...
- HAWQ取代传统数仓实践(十九)——OLAP
一.OLAP简介 1. 概念 OLAP是英文是On-Line Analytical Processing的缩写,意为联机分析处理.此概念最早由关系数据库之父E.F.Codd于1993年提出.OLAP允 ...
随机推荐
- JanusGraph中的事务
翻译整理:纪玉奇 几乎所有与JanusGraph的交互都是通过Transaction,JansuGraph的Transaction支持并发.使用Transaction时,不需要显式进行生命,gra ...
- js的常见函数
var n=0.0145; n.toFixed(2);//保留两位小数 n.lastIndexOf('a');//检索字符串最后出现的位置 n.indexof("h");//检索字 ...
- Python爬去图片实例,python 爬取图片
# coding:utf-8 import requests import re import time proxies = { "http": "http://124. ...
- Atitit.ati dwr的原理and设计 attilax 总结 java php 版本
Atitit.ati dwr的原理and设计 attilax 总结 java php 版本 1. dwr的优点相对于ajax来说..1 2. DWR工作原理1 3. Dwr的架构2 4. 自定义dwr ...
- python-sqlite3之占位符
The sqlite3 module supports two kinds of placeholders: question marks (qmark style) and named placeh ...
- 通过show status 来优化MySQL数据库
1, 查看MySQL服务器配置信息 Java代码 mysql> show variables; 2, 查看MySQL服务器运行的各种状态值 Java代码 mysql> show ...
- PHP学习笔记(6)js点击刷新验证码
用“换一张”来控制验证码刷新,js脚本怎么写 宏朋雄 | 浏览 3663 次 2012-06-11 22:41 2012-06-12 01:49 最佳答案 <img src=“验证码文 ...
- Qt之模式、非模式对话框
关于“模式”和“非模式”对话框,相信大家都比较熟悉,但其中有一个可能很多人都比较陌生,介于两者之间的状态,我们称之为“半模式“. 模式对话框 描述 阻塞同一应用程序中其它可视窗口输入的对话框.模式对话 ...
- 在一个验证form的实例中扩展jQuery.validate
需求很简单,直接上图: 要验证表单上的3个input输入框的格式,要求如下: 主关键词情形1: 浙江 杭州 温州 主关键词情形2: 浙江|江苏|上海,但是不能用 空格和 | 混合用,也就是情形1和2不 ...
- flask 中xx.init_app(app)方法
bootstrap = Bootstrap() mail = Mail() moment = Moment() db = SQLAlchemy() def create_app(config_name ...