前言

在进行一个应用系统的开发过程中,从上到下一般需要四个构件:客户端-业务逻辑层-数据访问层-数据库,其中数据访问层是一个底层、核心的技术。而且在实际开发中,数据库的操作也就是说数据访问层都是嵌套在其他语言中的,其是编程的核心。本文面向的是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():关闭游标对象

在上面的方法中提到了一个关键名词:事务,什么是事务呢?他是访问和更新数据的一个程序执行单元,很多操作的一个集合,有四个特点:

原子性:事物中包括的诸操作要么都做,要么都不做

一致性:事务必须使数据库从一致性状态变到另一个一致性状态

隔离型:一个事务的执行不被其他事务干扰

持久性:事务一旦提交,它对数据库的改变就是持久性的

事务的上述特点正是我们完成银行转账操作的关键。

具体实现

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

关闭自动commit()

正常结束事务:conn.commit(),

异常结束事务:conn.rollback()

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

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

#coding:utf-8

import sys

import MySQLdb

class TransferMoney():

def __init__(self,conn):

self.conn = conn

def transfer(self,src,target,money):

try:

self.check_acct_available(src)

self.check_acct_available(target)

self.has_enough_money(src,money)

self.reduce_money(src,money)

self.add_money(target,money)

self.conn.commit()

except Exception as e:

print e

self.conn.rollback()

def reduce_money(self,money):

cursor = self.conn.cursor()

try:

sql = "update account set money = money - %s where acctid = %s" %(money,src)

cursor.execute(sql)

print "reduce_money: " + sql

#rs = cursor.fetchall()

if cursor.rowcount != 1:

raise Exception("the account reduce money fail")

finally:

cursor.close()

def add_money(self,money):

cursor = self.conn.cursor()

try:

sql = "update account set money = money + %s where acctid = %s" %(money,target)

cursor.execute(sql)

print "add_money: " + sql

#rs = cursor.fetchall()

if cursor.rowcount != 1:

raise Exception("the account add money fail")

finally:

cursor.close()

def check_acct_available(self,accit):

cursor = self.conn.cursor()

try:

sql = "select * from account where acctid = %s" %accit

cursor.execute(sql)

print "check_acct_available: " + sql

rs = cursor.fetchall()

if len(rs) != 1:

raise Exception("the account %s is not exist" %accit)

finally:

cursor.close()

def has_enough_money(self,money):

cursor = self.conn.cursor()

try:

sql = "select * from account where acctid = %s and money >= %s " %(src,money)

cursor.execute(sql)

print "has_enough_money: " + sql

rs = cursor.fetchall()

if len(rs) != 1:

raise Exception("the account does not have enough money")

finally:

cursor.close()

if __name__ == "__main__":

source_acctid = sys.argv[1]

target_acctid = sys.argv[2]

money = sys.argv[3]

conn = MySQLdb.connect(

host = "127.0.0.1",user = '******',passwd = '******',port = 3306,db = '******'

)

tr_money = TransferMoney(conn)

try:

tr_money.transfer(source_acctid,money)

except Exception as e:

print e

finally:

conn.close()

总结

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

python查询银行汇款_基于Python实现一个简单的银行转账操作相关推荐

  1. python 头条 上传_基于Python的免费新闻头条接口查询

    一.开通接口 新闻头条接口服务使用的聚合数据提供的免费接口,每天可以100次免费调用.可以通过https://www.juhe.cn/docs/api/id/235注册及开通. 二.Python发起接 ...

  2. python 工资管理软件_基于[Python]的员工管理系统

    基于[Python]的员工管理系统 -------------------------------- 简介 使用python语言来完成一个员工管理系统,员工信息包含:员工工号,姓名, 年龄,性别,职位 ...

  3. python实现实时监控_基于 Python 的交换机实时监控系统的设计与实现

    从高校校园网运维工作实际出发,论文提出了一种基于 Python 语言+SNMP协议的网络交换机监测系统设计思路与实现方法.整个系统系统采用B/S模式,基于轻量级的web开发框架web.py实现.后端采 ...

  4. python实现离线翻译_基于python实现百度翻译功能

    运行环境: python 3.6.0 今天处于练习的目的,就用 python 写了一个百度翻译,是如何做到的呢,其实呢就是拿到接口,通过这个接口去访问,不过中间确实是出现了点问题,不过都解决掉了 先晾 ...

  5. python人脸识别库_基于Python的face_recognition库实现人脸识别

    Python Python开发 Python语言 基于Python的face_recognition库实现人脸识别 一.face_recognition库简介 face_recognition是Pyt ...

  6. python多叉树遍历_基于Python的多叉树遍历算法

    [ 综直厘翹 S 赛理 ) 信息记录材料 2019 年 5 月第 20 卷第 5 期 基于 Python 的多叉树遍历算法 钱雨波 , 王金祥 ( 指导老师 ) ( 延边大学 吉林 延边 1 3300 ...

  7. python电影推荐算法_基于Python的电影推荐算法

    原标题:基于Python的电影推荐算法 第一步:收集和清洗数据 数据链接:https://grouplens.org/datasets/movielens/ 下载文件:ml-latest-small ...

  8. python相关毕设题目_基于java的一个有创意的web毕设题目

    基于java的一个有创意的web毕设题目 一个有创意的web毕设题目 本课题将结合基于Java Web技术的名师一对一课程预约系统,根据本课题的最终目标,在线用户注册.相关信息发布.在线咨询.预约试听 ...

  9. python实现日历功能_基于python实现简单日历

    本文实例为大家分享了python实现简单日历的具体代码,供大家参考,具体内容如下 首先要理清楚逻辑,日历的难点在于如何使用基础知识将周几与对应的日期进行对应,我这里利用了1917年1月1日为星期1,计 ...

最新文章

  1. cuda error invalid argument
  2. rt linux 测试,rtlinux 的配置和测试
  3. 深度学习-Tensorflow2.2-深度学习基础和tf.keras{1}-逻辑回归与交叉熵概述-05
  4. Java递归基础案例-回文字符串的判断
  5. 如何构建一个流量无损的在线应用架构 | 专题尾篇
  6. elastic-job动态任务配置
  7. 下来安成功 打开一直白屏_苹果手机白屏怎么解决啊,苹果手机白屏了怎么修复...
  8. 端口占用问题解决办法(以1099端口为例)
  9. mysql的数学函数开方_MySQL数学函数简明总结
  10. 小程序技术可以提升桌面应用安全等级?
  11. C++与C调用so文件
  12. arduino mega针脚_Arduino MEGA中文数据手册
  13. java根据excel中的手机号查询归属地并添加到excel
  14. 2021.05.09 美团测开笔试-弹吉他
  15. 【不忘初心】Win10_20H2_2009_19042.572_X64_六合一_[纯净精简版](2020.10.29)
  16. GST: Grouped Spatial-Temporal Aggregation for Efficient Action Recognition 论文阅读
  17. yum不能使用了,怎么办?记下来!!!
  18. 佳能MG3600系列打印机如何更换连接WiFi
  19. MPD软件工作坊北京站:技术创新与研发效率带来的前沿思考
  20. (转)第三十七节、人脸检测MTCNN和人脸识别Facenet(附源码)

热门文章

  1. FileManager 文件管理器
  2. 包装实现一个具有重试机制的RestTemplate
  3. Spring Boot整合海外第三方支付Coda Payments
  4. 基于单片机的电子秤(计价时钟播报)系统设计(#0444)
  5. Secure CRT 7.0 通过 SSH服务登录 Vmware 下的Ubuntu 12.04服务器
  6. 115浏览器 for mac(多功能网页浏览器)
  7. 深入理解CSS之flex精要之 flex-basis flex-grow flex-shrink 实战讲解
  8. 圆周率一千万亿位_圆周率计算已经达到数万亿位,为何还在继续计算?
  9. 2018秋招前端笔试题(58同城)
  10. gks的定义计算机图形学,计算机图形学(概念)