一、作业信息

博客班级

软件工程

作业要求 作业要求
作业目标 你理解的作业目标具体内容
学号 3180701218

二、题目要求

编写一个ATM管理系统,语言不限,要求应包括以下主要功能:
(1)开户,销户
(2)查询账户余额
(3)存款
(4)取款
(5)转账(一个账户转到另一个账户)等...

三、代码

这次作业用SQL sever+VS2019写的,主要想复习一下去年学的SQL语言,再熟悉熟悉VS2019编写环境。

1、SQL代码

(1)首先建立ATM数据库和银行账户信息表masge,信息表存有用户的姓名、银行卡号、身份证号、电话、密码、余额等信息。

  1. create database ATM
  2. create table masge
  3. (
  4. name char(10) not null--姓名,
  5. id char(18) primary key--身份证号,
  6. cnode char(19) not null unique--银行卡号,
  7. cal char(11) not null unique--电话号码,
  8. code char(50) not null,--这里银行卡和注册密码一样
  9. balance int--余额
  10. )
  11. go

(2)ATM管理系统需要实现开户、注销、查询、存款、取款、转账等功能,这里都使用存储过程来实现。

①开户

用户输入姓名、身份证号、银行卡号、电话号码、密码,并判断该用户是否已注册。其中result和msg是存储过程的输出变量,result是布尔变量,用作开户是否成功的标志;msg是字符串变量,存放开户是否成功的信息。

  1. create proc login
  2. @name char(10),
  3. @id char(18),
  4. @cnode char(19),
  5. @cal char(11),
  6. @code char(50),
  7. @result bit out,
  8. @msg char(200) out
  9. as
  10. begin
  11. if exists(select id from masge where id=@id)begin
  12. select @result=0,@msg='用户已存在!'
  13. end else begin
  14. begin try
  15. insert into masge(name,id,cnode,cal,code)
  16. values(@name,@id,@cnode,@cal,@code)
  17. end try
  18. begin catch
  19. select @result=0,@msg=error_message()
  20. end catch
  21. end
  22. end
  23. go

②注销

  1. create proc logout
  2. @id char(18)
  3. as
  4. begin
  5. delete
  6. from masge
  7. where id=@id
  8. end
  9. go

③查询

  1. create proc inquire
  2. @id char(18),
  3. @balance int output
  4. as
  5. begin
  6. select @balance=balance from masge where id=@id
  7. end
  8. go

④存款

  1. create proc saves
  2. @id char(18),
  3. @balance int
  4. as
  5. begin
  6. update masge
  7. set balance=balance+@balance
  8. where id=@id
  9. end
  10. go

⑤取款

  1. create proc withdraw
  2. @id char(18),
  3. @m int
  4. as
  5. begin
  6. update masge
  7. set balance=balance-@m
  8. where id=@id
  9. end
  10. go

⑥转账

这里使用了事务,若用户身份证号输入错误,事务回滚转,不执行账操作;如果用户操作正确,继续执行。

  1. create proc transfer
  2. @id char(18),
  3. @id_ char(18),--被转的账户
  4. @m int,
  5. @result bit out,
  6. @msg char(200) out
  7. as
  8. begin
  9. begin tran --开始事务
  10. begin try
  11. if not exists(select * from masge where id=@id_)begin
  12. select @result=0,@msg='用户不存在'
  13. end else begin
  14. update masge
  15. set balance=balance-@m
  16. where id=@id
  17. update masge
  18. set balance=balance+@m
  19. where id=@id_
  20. select @result=1,@msg=''
  21. end
  22. end try
  23. begin catch
  24. select @result=0,@msg=error_message()
  25. end catch
  26. if(@result=0)begin
  27. rollback tran --执行出错,回滚事务
  28. end else begin
  29. commit tran --没有异常,提交事务
  30. end
  31. end
  32. go

⑦登录

  1. create proc logon
  2. @id char(18),
  3. @code char(50),
  4. @result bit out,--返回值
  5. @msg char(200) out--返回信息
  6. as
  7. begin
  8. begin try
  9. if not exists(select id from masge where id=@id)begin
  10. select @result=0,@msg='用户不存在!'
  11. end else if not exists(select * from masge where code=@code and id=@id)begin
  12. select @result=0,@msg='密码错误!'
  13. end else begin
  14. select @result=1,@msg=''
  15. end
  16. end try
  17. begin catch
  18. select @result=0,@msg=error_message()
  19. end catch
  20. end
  21. go

2、VS2019连接SQL数据库

VS2019连接SQL数据库,以及相关的网页项目操作,这里就不多说了,感兴趣的话可以看看下面up主的视频
SQL Server项目实战

四、运行截图

①登录与注册









②查询



③存款



④取款



⑤转账



⑥注销

五、psp表格

psp2.1 任务内容 计划完成需要的时间(min) 实际完成需要的时间(min)
Planning 计划 10 10
Estimate 估计这个任务需要多少时间,
并规划大致工作步骤
10 5
Development 开发 100 120
Analysis 需求分析(包括学习新技术) 12 5
Design Spec 生成设计文档 5 10
Design Review 设计复审 5 5
Coding Standard 代码规范 3 2
Design 具体设计 10 20
Coding 具体编码 36 50
Code Review 代码复审 5 7
Test 测试(自我测试,修改代码,提交修改) 10 20
Reporting 报告 9 6
Test Report 测试报告 3 2
Size Measurement 计算工作量 2 1
Postmortem & Process Improvement Plan 事后总结,并提出过程改进计划 3 3

六、总结

功能不太完善,由于时间原因,该系统只能检测用户是否存在,没有判断输入的银行卡号和该人信息是否符合;

操作繁琐,该系统是在web窗体执行的,ASP.net项目中,点击Button,就会发生页面刷新,之前定义的全局变量的值就会消失,因此用户登录时输入的身份证号无法保存,用户进行查询、转账等操作时需要频繁输入身份证号。

ATM管理系统(三)的更多相关文章

  1. 个人作业三——ATM管理系统

    一 作业信息 博客班级 https://edu.cnblogs.com/campus/ahgc/AHPU-se-JSJ18/ 作业要求 https://edu.cnblogs.com/campus/a ...

  2. ATM管理系统

    一.题目要求 编写一个ATM管理系统,语言不限,要求应包括以下主要功能: (1)开户,销户 (2)查询账户余额 (3)存款 (4)取款 (5)转账(一个账户转到另一个账户)等 二.代码提交 开户 pu ...

  3. IntelliJ IDEA14.0.3+Maven+SpringMVC+Spring+Hibernate光速构建Java权限管理系统(三)

    注册登录 --利用简单的编写注册登录系统来打通从前端到后台的数据传输路径. 一.建立数据库.基本表 基本环境:mysql5,7.Navicat for MySQL11.0.9企业版. 我们在本地MyS ...

  4. 基于VUE实现的新闻后台管理系统-三

    开始coding啦 ¶分析项目 根据展示效果我们可以分析出,Web页面有两个,一个用于登录,一个用于系统内容控制,我们分别将其命名为Login和Cms,然后进行路由配置. 在src/page下新建Lo ...

  5. 用Backbone.js创建一个联系人管理系统(三)

    原文: Build a Contacts Manager Using Backbone.js: Part 3 欢迎回到这系列的教程,关注使用Backbone.js构建应用程序. 如果你还没看过第一,二 ...

  6. step by step 之餐饮管理系统三

    1.说明 表名的长度最长为18个字符 茶色的字段为主键或联合主键 浅黄色的字段为索引 浅灰底色的字段为临时表中比正式表多出的字段 数据库系统:Sqlserver2008 脚本工具:使用CodeGene ...

  7. 基于Quartz.net的远程任务管理系统 三

    在上一篇中,已经把服务端都做好了.那接下来就是Web的管理端了,因为很多时候服务器是有专门的运维来管理的,我们没有权限去操作,所以有个可以管理Job的工具还是很有必要的. Web管理端,我选择现在很成 ...

  8. 新闻cms管理系统(三) ------菜单管理

    1.前期准备工作 (1)模板介绍 添加菜单的模板页面 菜单管理首页: 添加菜单页面: (2)公共类引入介绍 公共函数文件的引入(位置: Application/Admin/Controller/Com ...

  9. Django 练习班级管理系统三 -- 分页

    在 user_manager 项目下创建一个 python package:utils,里面创建一个 page.py 文件 page.py 文件内容为: # 创建一个 PagerHelper 类 cl ...

随机推荐

  1. spring-boot-route(二十三)开发微信公众号

    在讲微信公众号开发之前,先来大概了解一下微信公众号.微信公众号大体上可以分为服务号和订阅号,订阅号和服务号的区别如下: 服务号可以申请微信支付功能. 服务号只能由企业申请,订阅号可以有企业或个人申请. ...

  2. List集合,对象根据某个相同的属性,合并另外属性

    描述及实现: 1.List中有 Modular字段值有重复一样的2.Modular字段一样的话去重并且OrderAmount相加 HashMap<String,DataReport> te ...

  3. 本地文件r如何上传到github上

    来源:http://www.cnblogs.com/shenchanghui/p/7184101.html 来源:http://blog.csdn.net/zamamiro/article/detai ...

  4. python爬虫 学习1

    1 import requests 2 from bs4 import BeautifulSoup 3 import bs4 4 def gethtmltext(url): #获取html内容,利用t ...

  5. TCP 队列溢出了

    一.TCP 队列 1.syns queue:半连接队列 TCP 三次握手(参考:TCP建立连接之三次握手),第一步,服务端接收到客户端发送的 syn 消息后,将连接信息放入 syns queue,此时 ...

  6. Netty源码解析 -- 事件循环机制实现原理

    本文主要分享Netty中事件循环机制的实现. 源码分析基于Netty 4.1 EventLoop 前面分享服务端和客户端启动过程的文章中说过,Netty通过事件循环机制(EventLoop)处理IO事 ...

  7. Scala-1-字符处理

    // s插值val s = s"a = $a, b = $b"val s = s"a = ${a*2}, b = ${b*3}" // 顶格 及 插值val s ...

  8. 热部署只知道devtools吗?JRebel不香吗?

    持续原创输出,点击上方蓝字关注我 目录 前言 JRebel收费怎么破? 什么是本地热部署? 什么是远程热部署? JRebel和devtools的区别 如何安装JRebel? 如何本地热部署? 如何远程 ...

  9. 从ReentrantLock加锁解锁角度分析AQS

    本文用于记录在学习AQS时,以ReentrantLock为切入点,深入源码分析ReentrantLock的加锁和解锁过程. 同步器AQS的主要使用方式是继承,子类通过继承同步器并实现它的抽象方法来管理 ...

  10. .netcore中的依赖注入

    IOC.DI相关概念的理解 1.依赖:简单的讲就是"引用到".例如AccountController.cs引用到IAccountService.cs,那么AccountContro ...