位置: 编程技术 - 正文

基于Python实现一个简单的银行转账操作(用python做)

编辑:rootadmin

推荐整理分享基于Python实现一个简单的银行转账操作(用python做),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:利用python进行,基于python的程序设计,基于python的算法,基于python的程序设计,基于python的程序设计,用python编写,基于python的程序设计,基于python语言,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

在进行一个应用系统的开发过程中,从上到下一般需要四个构件:客户端-业务逻辑层-数据访问层-数据库,其中数据访问层是一个底层、核心的技术。而且在实际开发中,数据库的操作也就是说数据访问层都是嵌套在其他语言中的,其是编程的核心。本文面向的是python语言,即通过python操作数据库来实现简单的银行转账操作。

工具

python提供了python DB API用来统一操作数据库,使访问数据库的接口规范化,在没有python DB API之前,接口程序十分混乱,不同的数据库需要不同的操作接口,所以这个接口提供了极大的方便。在具体操作的时候,我们需要操作数据库以及其他逻辑的python代码,数据库连接对象connection来建立连接,数据库交互对象cursor来“运送”数据,一个健壮的系统必不可少的便是数据库异常类Exceptions。整个访问数据库流程如下图:

接下来分别介绍下两个主要对象:

connection:数据库连接对象,建立python客户端与数据库的网络连接。创建方法:MySQLdb.connect(),包括的主要成员方法:cursor():使用该连接创建并返回游标commit():提交当前事务rollback():回滚当前事务close()关闭连接cursor:游标对象,用于执行查询与获取结果,cursor对象支持的主要方法如下:execute():执行SQL语句,将结果从数据库获取到客户端fetchone():取得结果集的下一行fetchmany(size):获取结果集的下size行fetchall():获取结果集中剩下的所有行rowcount:最近一次execute返回数据的行数close():关闭游标对象在上面的方法中提到了一个关键名词:事务,什么是事务呢?他是访问和更新数据的一个程序执行单元,很多操作的一个集合,有四个特点:

基于Python实现一个简单的银行转账操作(用python做)

原子性:事物中包括的诸操作要么都做,要么都不做一致性:事务必须使数据库从一致性状态变到另一个一致性状态隔离型:一个事务的执行不被其他事务干扰持久性:事务一旦提交,它对数据库的改变就是持久性的事务的上述特点正是我们完成银行转账操作的关键。

具体实现

在开发中我们怎么样使用事务呢?

关闭自动commit()正常结束事务:conn.commit(),异常结束事务:conn.rollback()在银行转账系统中,需要考虑如下需求:比如A给B转账,当A账户上减少了M钱时,必须在B账户上多了M钱,不能A减了B没加,也不能B加了A还没有减,当然账户必须是有效的,M钱的金额肯定要大于A账户上的金额。所以在具体设计的时候,需要将A账户的金钱减少和B账户的金钱增加作为一个事务,要么同时成功,要么一起失败。按照这个需求,书写代码,详细代码见github,代码复制和数据库如下,有两个账户,分别拥有金钱和,在运行代码的时候在参数栏输入1,2,(source_acctid, target_acctid, tranfer_money)。

整个代码的逻辑如下:首先连接数据库,之后执行逻辑,然后断开数据库连接,执行的逻辑包括检查转账双方的账户是否有效,转账金额是否多于转账人的账户余额,分别给转账双方的帐号金额发生变化。如果正常结束事务,提交修改数据库,否则回滚。

总结

通过对数据库的操作就可以实现一个简单的银行转账系统,所以在系统开发的时候,我们应该尽最大的可能,让整个系统不只是多个组件的拼接,应该实现1+1>2。

Python实现Linux命令xxd -i功能 一.Linuxxxd-i功能Linux系统xxd命令使用二进制或十六进制格式显示文件内容。若未指定outfile参数,则将结果显示在终端屏幕上;否则输出到outfile中。详细

Python求算数平方根和约数的方法汇总 一、求算术平方根a=x=int(raw_input('Enteranumber:'))ifx=:whilea*ax:a=a+ifa*a!=x:printx,'isnotaperfectsquare'else:printaelse:printx,'isanegativenumber'二、求约数方法一:divisor=[]x=int(

Python装饰器基础详解 装饰器(decorator)是一种高级Python语法。装饰器可以对一个函数、方法或者类进行加工。在Python中,我们有多种方法对函数和类进行加工,比如在Python闭包

标签: 用python做

本文链接地址:https://www.jiuchutong.com/biancheng/383389.html 转载请保留说明!

上一篇:Python切片知识解析(python切片菜鸟教程)

下一篇:Python实现Linux命令xxd -i功能(linux python gui)

  • 增值税纳税申报表在哪里查询
  • 现金流量表年报中的上年金额是什么
  • 收到没有填税号的短信
  • 金蝶旗舰版的现金流量表怎么导出
  • 资产负债表其他流动资产包括什么
  • 服务类公司没有营业执照
  • 建筑施工企业会计制度
  • 房产折旧计算方法 举例
  • 物流企业会计核算的主要内容
  • 资产组减值测试要包含使用权资产吗
  • 研发费用加计扣除行业
  • 产品成本核算过程
  • 当月的费用次月入账可以么
  • 小规模纳税人代理记账一般多少钱
  • 增值税税控系统的税务处理
  • 管理会计的目标包括多选题
  • 贸易公司购买汽车的发票可以用抵公司的税吗
  • 2019水利基金税率是多少
  • 如何界定企业所得税的不征税收入与应税收入
  • 企业合并三种方式
  • 上月预付款项 这月开了发票会计分录
  • 设备租赁成本会计分录
  • 国家减免税额怎么入账
  • 取得运输单位开具的普通发票
  • 什么情况下个税税率是10%
  • 小规模纳税人的增值税计入成本吗
  • 小规模给个人开普票怎么填写
  • 收到返还代扣代缴手续费如何入账?
  • 反映企业在一定会计期间经营成果的会计报表
  • win11怎么用win10界面
  • linux禁止ip访问80端口
  • 企业租用个人房屋
  • 向农户收购农产品怎么打款
  • 在vue中如果computed属性是一个异步操作怎么办?
  • 固定资产有何特征?
  • 季报的利润表本月金额填的是当月数可以吗
  • php实用教程
  • 可供出售权益工具减值
  • dos命令怎么转到d盘
  • 其他应收款等于
  • 拆迁补偿账务处理办法
  • 什么叫做关税完税证明呢
  • mysql 5.7特性
  • 公章变更需要到哪个部门
  • 财务费用的相关认定
  • 以前年度损益调整结转到本年利润吗
  • 没有发票的运输费用怎么入账
  • 用公司名义买的东西送礼需要归还么
  • 一般纳税人简易计税方法适用范围
  • 研发支出是什么性质的科目
  • 捆绑销售如何做税务处理合适?
  • 银行存款利息如何计算
  • 奖金是职工福利?
  • 厨师的工资计入什么费用
  • 销售废旧物资账务处理
  • 发票验旧后才能领新发票吗
  • 应收及预付款项的坏账损失应当于实际发生时计入
  • 红字发票怎么申报增值税
  • 推广费计入哪个科目
  • 税局关于企业费用报销
  • 出口的样品如何销售
  • 公对私 预付款 税
  • linux rpm包怎么安装
  • WINDOWS系统中删除放入回收站的文件占用什么空间
  • 如果不用2b橡皮擦2b铅笔 能扫的出来吗
  • warning bios upgrade
  • vcspawn.exe
  • vc_mbcsmfc.exe是什么
  • win8.1使用教程
  • linux与windows有哪些主要区别
  • 如何解决windows蓝屏问题
  • win7系统重启后黑屏不进系统
  • linux的虚拟终端有几个
  • javascript概述及作用
  • 简述jquery的实现原理
  • 读长沙师范学院收费多少钱
  • android车载导航刷机包
  • ssh远程登录脚本
  • 新的开始励志句子
  • 本期应纳的增值税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设