01 - 开发成功的Oracle应用
笔记
1. 开发数据库应用,不能把数据库当黑盒。需要了解数据库的一下内容
- 数据库的体系结构
- 并发控制
- 开发的时候就要调优你的代码
- 数据库有哪些特性,不要在你的代码里重复实现
- 深入的学习SQL
2. 我的方法
以数据库为中心的方法.如果能在数据库中实现,就不去自己实现. 原因是Oracle在各种平台上都可用,自己实现的话,移植性可能会不好.
一些最佳实践
- 尽量使用一条SQL完成工作
- 如果一条SQL没法完成工作,那么就是用PL/SQL
- 尽量保持代码简单,要知道代码越多越容易出错
- 如果PL/SQL不能完成工作,就试试JAVA存储过程
- 如果Java不行,那么就试试C例程
- 再不行,就要考虑这个工作的可行性了。
3. 一个bitmap index引起阻塞的问题
自治事务
自治事务就是在一个已有的会话中开始一个独立的子事务,父事务被阻塞。通常用在测试中。
举一个位图索引导致的阻塞问题
先看位图索引的结构
比如拿 gender作例子,values=M or F, 建立bitmap index
假设表里有5条记录,那么位图中的bit数就是5
John, M,25, L1
Diana, F, 20, L2
Mary, F, 21, L1
Peter, M, 26, L4
Kathy, F, 33,L3
那么M的位图就是10010, F的位图就是01101. 如果bitmap index在列上, 那么L1=10100, L2=01000
那么如果在下面会话中打开一个自治事务,就会发生死锁。
ops$tkyte%ORA11GR2>>> create table t ( processed_flag varchar2() ); Table created. ops$tkyte%ORA11GR2> create bitmap index t_idx on t(processed_flag); Index created. ops$tkyte%ORA11GR2> insert into t values ( 'N' ); row created. ops$tkyte%ORA11GR2> declare pragma autonomous_transaction; begin insert into t values ( 'N' ); commit; end; / declare * ERROR at line : ORA-: deadlock detected while waiting for resource ORA-: at line
如果打开一个新的会话,同样插入值=N的行,那么这个会话会被阻塞,因为会话1已经锁定了Value=N的位图索引。
解决办法就是删除这个bitmap index.
4. 开发数据库应用的正确方法
- 了解数据库的体系结构, shared server or dedicate server
- 使用绑定变量, JDBC PreparedStatement
- hard code 参数会导致SQL 解析,重新编译查询计划
- 理解并发控制,SELECT for update, upd_date列,防止丢失更新
- 多版本控制,undo, 读一致性
- 非阻塞读
- 。。。
01 - 开发成功的Oracle应用的更多相关文章
- 【Todo】抽象渗漏法则 & 找到理想员工 & 软件开发成功 12 法则 & Joel on Software
Joel应该是个软件专家,这是他文章汇总的中文版本: http://local.joelonsoftware.com/wiki/Chinese_%28Simplified%29 其中有几篇值得好好看看 ...
- linux 成功安装oracle后,为其创建一个登录账户
成功安装oracle后,创建一个登录账户 1.切换到oracle用户下 su -l oracle 2.使用sysdba账户登录: sqlplus / as sysdba 3.创建用户 语法:CREAT ...
- HTML5学习总结-01 开发环境和历史
1 搭建HTML5开发环境 1 安装一款支持HTML5的浏览器 FireFox, Chrome 2 开发工具 SublineText, Eclipse, HBuilder, WebStorm 注:使用 ...
- 『OGG 01』Win7 配置 Oracle GoldenGate 踩坑指南
安装 Oracle 安装 Oracle11g 32位[Oracle 32位的话,OGG 也必须是 32位,否则会有0xc000007b无法正常启动 错误] 安装目录为 D:\oracle\produc ...
- 开发成功-cpu-mem监控动态折线图--dom esayui js java
jsp ------------------------------------------------------------------------------------------- ---- ...
- VS2015下的Android开发系列01——开发环境配置及注意事项
概述 VS自2015把Xamarin集成进去后搞Android开发就爽了,不过这安装VS2015完成的时候却是长了不知道多少.废话少说进正题,VS2015安装时注意把Android相关的组件勾选安装, ...
- Java学习笔记(十三)——通过Netbeans开发环境生成oracle数据库中表的对应hibernate映射文件
[前面的话] 身体慢慢已经快好了,感觉真好,哈哈. 这篇文章要通过Hibernate对数据库进行操作,而Netbeans可以直接通过数据库逆向生成对应的映射文件.基础文章,选择性阅读. [步骤] 1. ...
- Vulkan Tutorial 01 开发环境搭建之Windows
操作系统:Windows8.1 显卡:Nivida GTX965M 开发工具:Visual Studio 2017 相信很多人在开始学习Vulkan开发的起始阶段都会在开发环境的配置上下一些功夫,那么 ...
- Linux基础(01)开发环境的搭建
内核源码下载 : https://blog.csdn.net/u011375704/article/details/81866427 1.在虚拟机安装Ubuntu 14.04版本 (安装时设置好用户名 ...
随机推荐
- node.js的学习
require('http') 内置模块 server.js var http = require('http'); function start(){ server = http.createSer ...
- eclipse格式化代码末班修改
在窗口->首选项->输入format(格式)搜索,或者找Java->代码样式->格式化程序: 几个内置的不能调格式化代码风格,但是可以根据内置的新建一个,出来很多选项,开始调吧 ...
- nodeJs事件之监听移除事件
var EventEmitter=require('events').EventEmitter var life=new EventEmitter(); //comfort 求安慰,函数名: //fo ...
- selenium IDE--录制和回放脚本
1 selenium IDE--录制脚本 准备工作:firefox 浏览器安装了selenium IDE 插件 实例:打开百度搜索“软件测试” firefox浏览器打开网址:https://www.b ...
- 基于AutoCAD的空间数据共享平台雏形
好久没有更新博客了,今天先透露一个新的产品——AutoMap.我自己对于这个产品的定位是“基于AutoCAD的空间数据共享平台”.用一句话来概括AutoMap的功能:为用户提供一个在AutoCAD下访 ...
- 网络服务器带宽Mbps、Mb/s、MB/s有什么区别?10M、100M到底是什么概念?
网络服务器带宽Mbps.Mb/s.MB/s有什么区别?我们经常听到IDC提供的服务器接入带宽是10M独享,或者100M独享,100M共享之类的数据.这的10M.100M到底是什么概念呢? 工具/原料 ...
- 第五周&第六周
学习进度表 周数 专业学习目标 学习时间 新增代码行 博客发表量 人文方面学习 知识总结 第四周 认真掌握老师上课所讲的内容,在课外多学习一些知识 5小时 50 1 阅读 ...
- ACM--South Pacific 2012
题目链接:https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&category=5 ...
- Word2007插入两种页码
做毕设,摘要,Abstract,目录,第一章,现在想要“摘要,Abstract,目录”编页码“为罗马数字,第一章开始为阿拉伯数字,可以按如下步骤: 1.各部分插入分页符,这与插入两种页码无关,不过是为 ...
- AVFoundation的使用
AVFoundation的使用 2013-05-03 14:50:21| 分类: iphone_dev_note|举报|字号 订阅 相机相关应用一般会用到AVFoundation. ...