四、逻辑设计
ATM系统需要有用户信息,还要银行卡的信息,还需要交易信息,以供银行人员查询。
(1) 用户信息包括记录开户客户的相关信息存储开户客户的客户编号、姓名、身份证号、居住地
址和联系电话
(2) 交易信息记录银行卡的相关信息存储卡号号、货币类型、存款类型、开户日期、开户金额、
余额和顾客编号
(3) 银行卡记录交易的相关信息存储交易日期、交易卡号、交易类型、交易金额和备注信息
用户信息+开户名(customername)+顾客编号(customerID)+身份证(PID)交易信息+交易日期(transinfo)+交易金额(transmoney)+交易类型(transType )+卡号(cardID)+备注(remark)*1..*1*银行卡信息+卡号(cardID)+密码(pass)+开户日期(openDate)+存款类型(savingType)+开户金额(openMoney)+顾客编号(customerId)+余额(balance)+是否挂失(IsReportloss)+货币类型(curType)
6
五、物理设计
5.1表汇总 表名 功能说明 userinfo cardinfo transinfo 记录开户客户的相关信息存储开户客户的客户编号、姓名、身份证号、居住地址和联系电话 记录银行卡的相关信息存储卡号号、货币类型、存款类型、开户日期、开户金额、余额和顾客编号 记录交易的相关信息存储交易日期、交易卡号、交易类型、交易金额和备注信息 5.2 数据库表物理设计
表[1]: 交易信息表
表名 数据库用户 主键 其他排序字段 索引字段 序号 字段名称 transinfo 交易信息表 卡号 交易日期、交易金额 无 数据类型(精度范围) datetime char(30) char(10) money text ( transDate datetime default getdate() not null, cardID char(30) not null, transType char(10) check (transType like '存入'or transType like '支取'), transMoney money check (transMoney>0 ), remark text ) 允许为空Y/N N N N N N 唯一Y/N N Y N N N 区别度 默认值 约束条件/说明 1 2 3 4 5 transDate cardID transType transMoney remark sql脚本 中 高 中 中 中 无 无 无 无 无 交易日期 卡号 交易类型 交易金额 备注信息 create table transinfo 注备
7
无
表[2]:用户信息表
表名 数据库用户 主键 其他排序字段 索引字段 序号 1 2 3 4 5 字段名称 userinfo 用户信息表 顾客编号 开户名、身份证号 无 数据类型(精度范围) int varchar(20) char(18) char(15) varchar(50) 允许为空Y/N N N N N N 唯区别一度 Y/N Y N Y Y N 高 中 中 高 中 默认值 无 无 无 无 无 约束条件/说明 customerID customerName PID telephone address 主键/自动编号 客户姓名 身份证号码 电话 地址 表[3]: 银行卡信息表
表名 数据库用户 主键 其他排序字段 索引字段 序号 字段名称 cardinfo 银行卡信息表 卡号 开户日期、开户金额、余额 无 数据类型(精度范围) 允唯一许Y/N 为空Y/N N N N N N N N N N Y N N N N N N N Y 区别度 默认值 约束条件/说明 1 2 3 4 5 6 7 8 9
cardID curType savingType openDate openMoney balance pass IsReportLoss customerID char(30) char(5) char(15) datetime money money char(6) char(8) int 高 中 中 中 中 中 中 中 高 无 无 无 无 无 无 888888 无 无 主键/卡号 货币类型 存款类型 开户日期 开户金额 余额 密码 是否挂失 客户编号 8
5.3 视图的设计
1、建立一张最高交易信息的视图 目的:查找最高交易。
功能:能够及时展现最高交易。
意义:有利于数据库安全的维护,防止任意修改数据库中的交易信息
---最高交易
create view view_mosttransinfo(cardID,transMoney) as
select cardID,MAX (transMoney) from transinfo group by cardID; select *from view_mosttransinfo
2、建立一张周交易信息的视图
目的:查找一周内某卡得所有交易。 功能:能够及时展现一周的交易信息。
意义:有利于数据库安全的维护,防止任意修改数据库中的交易信息
--周交易
create view view_transinfo as
select transDate,cardID,transType,transMoney from transinfo where datediff(ww,'2013-06-10 00:00:00.0000000',getdate())=0; select *from transinfo;
2、建立一张查询挂失卡号的视图 目的:查找所有挂失了的卡号。
功能:能够及时展现那些卡号挂失了。
意义:有利于数据库安全的维护,防止客户信息泄露
--查询挂失卡号(查看所有挂失的卡号) create view view_IsReportLoss as
select cardID,IsReportLoss from cardinfo where IsReportLoss='是'; select *from view_IsReportLoss;
5.4 存储过程及触发器的设计
5.4.1 产生随机卡号存储过程 功能: 随机生成卡号
目的: 让客户能拿到随机的卡号,能避免重复的卡号出现 意义: 用随机卡号能让客户使用到随机的卡号
代码:
create procedure proc_cardinfo-----------创建开户存储过程 (
@savingType char(15),
9
@openMoney money, @balance money, @customerID int ) as
---*---------------声明固定的数字与随机的数字-------------------*/
declare @tempStr varchar(10) set @tempStr='1010 3576 '
declare @r numeric(10,8) --后8位随机数
/*----------------------产生随即因子----------------------*/
select @r=rand( (datepart(mm,getdate() )*10000) +(datepart(ss,getdate() )*1000) +datepart(ms,getdate()) )
/*-----截取@r中小数点后的四位随机数,再添加空格,再截取最后四位--*/ declare @cardID char(30) set @cardID =@tempStr+substring(convert(varchar(10),@r),3,4)+' '+substring(convert(varchar(10),@r),7,8)
INSERTINTOcardInfo(cardID,savingType,openMoney,balance,customerID)VALUES(@cardID,@savingType,@openMoney,@balance,@customerID)
5.4.2 解除挂失存储过程
功能:实现银行卡解除挂失功能
目的:银行卡找回或者记起密码银行卡解除挂失 意义:更好地保护客户信息 代码:
create procedure update1_IsReportLoss----------创建解除挂失存储过程 (@customerID varchar(20), @cardID varchar(20), @PID char(18) ) as
declare @IsReportLoss char(8) begin
if not exists(select *from cardInfo where customerID=@customerID) print '您输入的顾客编号不存在'
else if(@PID!=(select PID from userinfo where @customerID=customerID)) print'身份证错误,不能解挂。'
else if((select cardID from cardinfo where @customerID=customerID)!=@cardID) print'卡号错误,不能解挂。'
else if((select IsReportLoss from cardinfo where @customerID=customerID)='否') print'卡号未挂失,不用解挂。' else begin
update cardinfo set IsReportLoss='否' where cardID=@cardID;
10
百度搜索“77cn”或“免费范文网”即可找到本站免费阅读全部范文。收藏本站方便下次阅读,免费范文网,提供经典小说综合文库数据库ATM系统实训报告(2)在线全文阅读。
相关推荐: