python 简单的数据库操作之转账
2024-09-05 06:35:47
介绍:本文是关于数据库的简单操作,实现转账(只是修改数据库中用户的账户金额)的功能
模块介绍:首先是入口主函数 主函数中实现转账方法 以及异常的处理:
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 = 'root',passwd = 'root',port = 3306,db = 'account')
tr_money = TransferMoney(conn) try:
tr_money.transfer(source_acctid,target_acctid,money) #转账操作
except Exception as e:
print "出现问题" + str(e)
finally:
conn.close()#关闭数据库连接
然后是实现转账的类,以及类中实现的方法 1.判断用户账户中的金额 2.判断账户是否存在 3.扣除账户金额 4.增加账户金额
class TransferMoney(object): def __init__(self, conn):
self.conn = conn def check_acct_available(self, acctid):
cursor = self.conn.cursor()
try:
sql = "select * from account_user where accountid=%s"%acctid
cursor.execute(sql)
print "check_acct_available:"+sql
rs = cursor.fetchall()
if len(rs)!=1:
raise Exception("账号%s不存在"%acctid)
finally:
cursor.close() def has_enough_money(self, acctid, money):
cursor = self.conn.cursor()
try:
sql = "select * from account_user where accountid=%s and money>%s"% (acctid,money)
cursor.execute(sql)
print "has_enough_money:"+sql
rs = cursor.fetchall()
if len(rs)!=1:
raise Exception("账号%s没有足够的钱"%acctid)
finally:
cursor.close() def reduce_money(self, acctid, money):
cursor = self.conn.cursor()
try:
sql = "update account_user set money=money-%s where accountid=%s"% (money,acctid)
cursor.execute(sql)
print "reduce_money:"+sql
if cursor.rowcount!=1:
raise Exception("账号%s减款失败"%acctid)
finally:
cursor.close() def add_money(self, acctid, money):
cursor = self.conn.cursor()
try:
sql = "update account_user set money=money+%s where accountid=%s"% (money,acctid)
cursor.execute(sql)
print "add_money:"+sql
if cursor.rowcount!=1:
raise Exception("账号%s加款失败"%acctid)
finally:
cursor.close() def transfer(self,source_acctid,target_acctid,money):
try:
self.check_acct_available(source_acctid) #检查转账账户是否可用
self.check_acct_available(target_acctid)
self.has_enough_money(source_acctid,money) #检查账户钱是否足够
self.reduce_money(source_acctid,money) #扣除钱
self.add_money(target_acctid,money) #转账加钱
self.conn.commit()
except Exception as e:
self.conn.rollback() #如果有步骤出错 则事务回滚
raise e # raise的作用是将异常抛出到上一级处理
最新文章
- geotrellis使用(六)Scala并发(并行)编程
- SQL复制表结构或表数据
- ae 地理坐标与投影坐标转换 [转]
- EditPlus v4.5 简体中文
- Socket Programming in C#--Multiple Sockets
- sql server中index的REBUILD和REORGANIZE
- c++ ip地址相关
- Oracle language types(语言种类) 表的相关操作 DDL数据定义语言
- Oracle学习第三讲
- jQuery Moblile Demos学习记录Theming、Button、Icons图标,脑子真的不好使。
- php随机10-thinkphp 3.1.3 模板继承 布局
- String,StringBuffer以及StringBuilder的差别
- PowerDesigner创建物理模型
- 在java中和javascript中过滤掉类似于img形式的字符串,从而不显示图片
- [hdu3943]K-th Nya Number
- Java线程中断机制-如何中断线程
- [转帖] 百度知道: KMS 和OSPP
- PAT Basic 1009
- [原]Docker-issue(2) http: server gave HTTP response to HTTPS client
- Java知多少(86)文本框和文本区的输入输出
热门文章
- uva11609(组合数学,快速幂)
- 数据库迁移到Azure SQL Database用户无法登陆的问题
- boost库 bind/function的使用
- Gym - 100623J Just Too Lucky (数位dp)
- 242. Valid Anagram Add to List
- Linux下系统监控工具nmon使用
- set/multiset容器
- 在asp.net中使JQuery的Ajax用总结
- C# 代码注释和Config文件中,特殊符号的书写方法。
- k近邻算法C++二维情况下的实现