Python操作MySQL模拟银行转账
时间:2019-04-13
本文章向大家介绍Python操作MySQL模拟银行转账,主要包括Python操作MySQL模拟银行转账使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
今天在慕课网上学习了有关于python操作MySQL的相关知识,在此做些总结。python操作数据库还是相对比较简单的,由于python统一了各个数据库的接口程序,也就是所谓的Python DB,所以无论使用何种数据可,都可以用统一的接口对数据库进行操作。操作中主要涉及connection对象的操作和cursor的操作,前者主要是为了建立起python与数据库的数据交换通道,后者则是访问数据的游标,也可以理解为指针。数据库的相关结构化语言在Python中均是以字符串的形式呈现的。另外注意rollback的重要性,一旦操作失败,所有操作都要回滚到之前的状态,否则会发生错误。
另外,在编写实例的时候,对于面向对象的编程思路又有了新的认识,自顶向下的程序编写模式非常有利于拆分程序的功能,分而治之。面向对象的封装性在此提醒的淋漓尽致!
代码如下,在原有基础上,我又增加了添加记录的功能。
#coding=utf8 import MySQLdb import sys class TranseferMonet(object): def __init__(self,conn): self.conn = conn def createNewUser(self,userID,money): cursor = self.conn.cursor() try: sql = 'INSERT account VALUES(%s,%s)' %(str(userID),str(money)) cursor.execute(sql) self.conn.commit() except Exception as e: self.conn.rollback() raise e def transferMoney(self,transeferID,recivierID,money): try: self.checkID(transeferID) self.checkID(receiverID) self.checkEnoughMoney(transferID,money) self.subMoney(transferID,money) self.addMoney(receiverID,money) self.conn.commit() except Exception as e: self.conn.rollback() raise e def checkID(self,userID): cursor = self.conn.cursor() try: sql = 'SELECT userID FROM account WHERE userID = %s' %str(userID) cursor.execute(sql) rs = cursor.fetchall() if len(rs) != 1: raise Exception("ID错误!") finally: cursor.close() def checkEnoughMoney(self,transferID,money): cursor = self.conn.cursor() try: sql = 'SELECT money FROM account WHERE userID = %s and money >= %s' %(str(transferID),str(money)) cursor.execute(sql) rs = cursor.fetchall() if len(rs) != 1: raise Exception("余额不足!") finally: cursor.close() def subMoney(self,transferID,money): cursor = self.conn.cursor() try: sql = 'UPDATE account SET money = money-%s WHERE userID = %s' %(str(money),str(transferID)) cursor.execute(sql) if cursor.rowcount != 1: raise Exception('减款失败!') finally: cursor.close() def addMoney(self,receiverID,money): cursor = self.conn.cursor() try: sql = 'UPDATE account SET money = money+%s WHERE userID = %s' %(str(money),str(receiverID)) cursor.execute(sql) if cursor.rowcount != 1: raise Exception('加款失败!') finally: cursor.close() if __name__=="__main__": transferID = 2002 receiverID = 2001 money = 300 newID = 2003 newmoney = 900 conn = MySQLdb.connect(host = '127.0.0.1',port = 3306,user = 'root',passwd = '914767195',db = 'test',charset = 'utf8') trMoney = TranseferMonet(conn) try: trMoney.transferMoney(transferID,receiverID,money) except Exception as e: print "转账错误"+str(e) try: trMoney.createNewUser(newID,newmoney) except Exception as e: print "创建用户失败!"+str(e) finally: conn.close()
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
- MongoDB - basic
- spring boot启用tomcat ssl
- HTTP status code
- jackson简单使用,对象转json,json转对象,json转list
- 2016.07 第3周 群问题分享
- jackson error 含义log
- java删除文件夹
- JSP自定义tag
- gradle中使用嵌入式(embedded) tomcat, debug 启动
- spring in action 4th --- quick start
- Date, TimeZone, MongoDB, java中date的时区问题
- spring boot 添加拦截器
- spring boot 部署为jar
- 重定向Http status code 303 和 302
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- pip conda 安装速度慢解决方法
- Linux 中指定使用的GPU
- 未读消息(小红点),前端 与 RabbitMQ 实时消息推送实践,贼简单~
- Day13 :调整数组顺序使奇数位于偶数前面
- TensorFlow 指定GPU 日志却显示的是第0块
- bazel 出现no such package '@org_tensorflow//tensorflow' 错误
- tensorflow API——tf.random_uniform 使用
- go cannot find package "golang.org/x/crypto/ssh/terminal" 解决方案
- go 中的 defer 使用及其规则
- 数据结构算法操作试题(C++/Python/Go)——938 二叉搜索树的范围和
- Android Studio 代理配置了Gradle依旧连接超时
- Dart 中变量类型 var, Object, dynamic 区别
- C++ 中的static关键字使用场景
- Dart 中的生产模式和检查模式
- 使用mysqladmin工具统计mysql当前的T/QPS