数据库应用设计与实现

1、解析是为执行SQL语句做准备的过程,它涉及检查语句、权限、对像的有效性,以及创建执行计划(execution plan)。

     Oralce共享池(shared pool)中维护了一份SQL语句的缓存,如果在共享池中找到了匹配的SQL语句所对应的解析被称为软解析,否则,必须进行硬解析。

     硬解析不仅耗费CPU时间,在有大量会话要同时缓存SQL到共享池时还会造成争用。使用绑定变量并避免不必要的重解析,可显著降低解析开销与闩锁和互斥的争用。

 

2、批量检索记录可以减少发送到数据库服务器的请求次数,也可以降低网络流量和逻辑IO开销,对于批量查询来讲,批量提取大约可以带来一个数量级(10倍)的性能提升。

 

3、应用事务设计的基本目标是持有锁的时间尽可能短,然而,也不能为了提高并发而牺牲事务的完整性。

     悲观锁策略--记录可能会在被提取到与被更新的时间间隔内被其它用户更新。为避免任何争用,悲观锁要求你在检索到记录时立即锁住此记录。

     乐观锁策略--不需要在提取数据时锁住记录。然而,为避免记录在获取与修改时间内被更新,有必要在事务最终提交DML语句时检查此记录是否有发生变化。完成该任务方法有三种:时间戳、最初的数据选择标准是否仍有效、或用ORA_ROWSCN伪列。

 

      在10G中,ORACLE引入了一个伪列ORA_ROWSCN,访列为每条记录包含了一个系统变更号(system change number, SCN),如果表创建时没有使用rowdependencies关键字,则该列只包含了记录所在数据块中最大的SCN号。使用ORA_ROWSCN是确认记录有没变化最简单的方法。

 

乐观锁例:

...

select ORA_ROWSCN into v_start_rowscn

  from ...;

credit_check(p_cust_id);

update customers_rd

      set ...

where cust_id = p_cust_id

    and ora_rowscn = v_start_rowscn;

 

悲观锁例:

...

select cust_id into v_cust_id

  from customers_rd

where cust_id = p_cust_id for update;

credit_check(p_cust_id);

update customers_rd

      set ...

where cust_id = p_cust_id;

转载于:https://www.cnblogs.com/optimize/p/10112588.html

数据库应用系统设计实现 实验类型:设计型 实验地点:2楼312 实验时间:12月14日、21日周五1-3/5-7节 实验内容: 系统概述: 某银行需要开发ATM存取款机系统实现如下功能: 1)开户(到银行填写开户申请单,卡号自动生成) 2)取款 3)存款 4)查询余额 题目要求: 一、建库、建表、建约束 1、使用SQL创建表 客户信息表userinfo 字段名称 说明 备注 customerID 顾客编号 自动编号(标识列),从1开始,主键 用序列sequence实现,用其属性:nextval customerName 开户名 必填 PID 身份证号 必填,智能是18位或15位,唯一约束 check约束length()函数 telephone 联系电话 必填,11位手机号 check约束,’[0-9]’ address 居住地址 银行卡信息表cardinfo 字段名称 说明 cardID 卡号 必填,主键,银行的卡号规则和电话好吗一样,一般前8位代表特殊含义,如某综合某支行等,假定该行要求其营业厅的卡号格式为10103576**** ***开始,每4位号码后有空格,卡号一般是随机产生。 curType 货币种类 必填,默认为RMB savingTate 存款类型 活期/定活两便/定期 openDate 开户日期 必填,默认为系统当前日期 openMoney 开户金额 必填,不低于1元 balance 余额 必填,不低于1元,否则将销户 pass 密码 必填,6位数字,开户时默认为6个“6” IsReportloss 是否挂失 必填,是/否值,默认为“否” customerID 顾客编号 外键,必填,表示该卡对应的顾客编号,一位顾客允许办理多张卡号 交易信息表transinfo 字段名称 说明 transDate 交易日期 必填,默认为系统当前日期 cardID 卡号 必填,外键 transType 交易类型 必填,只能是存入/支取 transMoney 交易金额 必填,大于0 remark 备注 可选,其他说明 2、使用SQL语言在每个表上添加约束 主键约束、外键约束、CHECK约束、默认约束、非空约束 二、插入测试数据 使用SQL语言向每个表中插入至少3条记录 三、模拟常规业务 1)修改客户密码 2)办理银行卡挂失 3)统计银行资金流通余额和盈利结算 银行资金流通余额=总存入金额-总支取金额 盈利结算=总支取金额 * 0.008 – 总存入金额 * 0.003 4)查询本周开户的卡号,显示该卡相关信息 5)查询本月交易金额最高的卡号 6)查询挂失账号的客户信息 四、利用视图实现数据查询 1)为客户提供以下3个视图供其查询该客户数据 客户基本信息:vw_userInfo 银行卡信息:vw_cardInfo 银行卡交易信息:vw_transInfo 2)提供友好界面,要求各列名称为中文描述 3)调用创建的视图获得查询结果 五、用存储过程实现业务处理 1)完成开户业务 2)完成取款或存款业务 3)根据卡号打印对账单 4)查询、统计指定时间段内没有发生交易的账户信息
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值