Python操作MySQL模擬銀行轉(zhuǎn)賬
今天在慕課網(wǎng)上學(xué)習(xí)了有關(guān)于python操作MySQL的相關(guān)知識(shí),在此做些總結(jié)。python操作數(shù)據(jù)庫還是相對(duì)比較簡(jiǎn)單的,由于python統(tǒng)一了各個(gè)數(shù)據(jù)庫的接口程序,也就是所謂的Python DB,所以無論使用何種數(shù)據(jù)可,都可以用統(tǒng)一的接口對(duì)數(shù)據(jù)庫進(jìn)行操作。操作中主要涉及connection對(duì)象的操作和cursor的操作,前者主要是為了建立起python與數(shù)據(jù)庫的數(shù)據(jù)交換通道,后者則是訪問數(shù)據(jù)的游標(biāo),也可以理解為指針。數(shù)據(jù)庫的相關(guān)結(jié)構(gòu)化語言在Python中均是以字符串的形式呈現(xiàn)的。另外注意rollback的重要性,一旦操作失敗,所有操作都要回滾到之前的狀態(tài),否則會(huì)發(fā)生錯(cuò)誤。
另外,在編寫實(shí)例的時(shí)候,對(duì)于面向?qū)ο蟮木幊趟悸酚钟辛诵碌恼J(rèn)識(shí),自頂向下的程序編寫模式非常有利于拆分程序的功能,分而治之。面向?qū)ο蟮姆庋b性在此提醒的淋漓盡致!
代碼如下,在原有基礎(chǔ)上,我又增加了添加記錄的功能。
#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錯(cuò)誤!") 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 "轉(zhuǎn)賬錯(cuò)誤"+str(e) try: trMoney.createNewUser(newID,newmoney) except Exception as e: print "創(chuàng)建用戶失?。?+str(e) finally: conn.close()
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python+OpenCV目標(biāo)跟蹤實(shí)現(xiàn)基本的運(yùn)動(dòng)檢測(cè)
這篇文章主要為大家詳細(xì)介紹了Python+OpenCV目標(biāo)跟蹤實(shí)現(xiàn)基本的運(yùn)動(dòng)檢測(cè),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-07-07Python實(shí)現(xiàn)進(jìn)度條和時(shí)間預(yù)估的示例代碼
這篇文章主要介紹了Python實(shí)現(xiàn)進(jìn)度條和時(shí)間預(yù)估的代碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06python實(shí)現(xiàn)決策樹分類算法代碼示例
決策樹分類算法是最為常見的一種分類算法,通過屬性劃分來建立一棵決策樹,測(cè)試對(duì)象通過在樹上由頂向下搜索確定所屬的分類,下面這篇文章主要給大家介紹了關(guān)于python實(shí)現(xiàn)決策樹分類算法的相關(guān)資料,需要的朋友可以參考下2022-06-06Python使用watchfiles實(shí)現(xiàn)監(jiān)控目錄變更
在工作中難免會(huì)碰到這樣的需求,監(jiān)控指定目錄,下面小編就來和大家介紹一下如何利用watchfiles 模塊實(shí)現(xiàn)監(jiān)控目錄的變更,感興趣的可以了解下2023-09-09Python使用xpath實(shí)現(xiàn)圖片爬取
這篇文章主要介紹了Python使用xpath實(shí)現(xiàn)圖片爬取,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09pyautogui自動(dòng)化控制鼠標(biāo)和鍵盤操作的步驟
這篇文章主要介紹了pyautogui自動(dòng)化控制鼠標(biāo)和鍵盤操作的步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04使用 NumPy 和 Matplotlib 繪制函數(shù)圖
Matplotlib 是 Python 的繪圖庫。 它可與 NumPy 一起使用,提供了一種有效的 MatLab 開源替代方案。 它也可以和圖形工具包一起使用,如 PyQt 和 wxPython2021-09-09