python 多部操作 事務(wù)

https://www.cnblogs.com/gide/p/4771790.html

coding=utf-8

2 import sys
3 import MySQLdb
4
5 class TransferMoney(object):
6 def init(self,conn):
7 self.conn = conn
8
9 #檢查賬戶是否合法
10 def check_acct_avaiable(self,acctid):
11 cursor = self.conn.cursor()
12 try:
13 sql = "select * from account where acctid=%s" % acctid
14 cursor.execute(sql)
15 print "check account:" + sql
16 rs = cursor.fetchall()
17 if len(rs) != 1:
18 raise Exception("account %s illega" % acctid)
19 finally:
20 cursor.close()
21
22 #檢查是否有足夠的錢
23 def has_enough_money(self,acctid,money):
24 cursor = self.conn.cursor()
25 try:
26 sql = "select * from account where acctid=%s and money > %s" % (acctid,money)
27 cursor.execute(sql)
28 print "has enough money:" + sql
29 rs = cursor.fetchall()
30 if len(rs) != 1:
31 raise Exception("account %s not enough money" % acctid)
32 finally:
33 cursor.close()
34
35 #賬戶減錢
36 def reduce_money(self,acctid,money):
37 cursor = self.conn.cursor()
38 try:
39 sql = "update account set money = money-%s where acctid = %s" % (money,acctid)
40 cursor.execute(sql)
41 print "reduce_money:" + sql
42 if cursor.rowcount != 1:
43 raise Exception("reduce money fail %s" % acctid)
44 finally:
45 cursor.close()
46
47 #賬戶加錢
48 def add_money(self,acctid,money):
49 cursor = self.conn.cursor()
50 try:
51 sql = "update account set money = money+%s where acctid = %s" % (money,acctid)
52 cursor.execute(sql)
53 print "add_money:" + sql
54 if cursor.rowcount != 1:
55 raise Exception("add money fail %s" % acctid)
56 finally:
57 cursor.close()
58 #主執(zhí)行語句
59 def transfer(self,source_acctid,target_acctid,money):
60 try:
61 self.check_acct_avaiable(source_acctid)
62 self.check_acct_avaiable(target_acctid)
63 self.has_enough_money(source_acctid,money)
64 self.reduce_money(source_acctid,money)
65 self.add_money(target_acctid,money)
66 self.conn.commit()
67 except Exception as e:
68 self.conn.rollback()
69 raise e
70
71 if name == "main":
72 source_acctid = sys.argv[1]
73 target_acctid = sys.argv[2]
74 money = sys.argv[3]
75 conn = MySQLdb.Connect(host = '127.0.0.1',port=3306,user='root',passwd='',db='test',charset='utf8')
76 tr_money = TransferMoney(conn)
77
78 try:
79 tr_money.transfer(source_acctid,target_acctid,money)
80 except Exception as e:
81 print "Happen:" + str(e)
82 finally:
83 conn.close()

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末昆庇,一起剝皮案震驚了整個(gè)濱河市遗锣,隨后出現(xiàn)的幾起案子被啼,更是在濱河造成了極大的恐慌滑沧,老刑警劉巖甲雅,帶你破解...
    沈念sama閱讀 222,865評論 6 518
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蹄殃,死亡現(xiàn)場離奇詭異荤西,居然都是意外死亡伟桅,警方通過查閱死者的電腦和手機(jī)祠饺,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,296評論 3 399
  • 文/潘曉璐 我一進(jìn)店門越驻,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事缀旁〖桥” “怎么了?”我有些...
    開封第一講書人閱讀 169,631評論 0 364
  • 文/不壞的土叔 我叫張陵并巍,是天一觀的道長目木。 經(jīng)常有香客問我,道長懊渡,這世上最難降的妖魔是什么刽射? 我笑而不...
    開封第一講書人閱讀 60,199評論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮剃执,結(jié)果婚禮上誓禁,老公的妹妹穿的比我還像新娘。我一直安慰自己肾档,他們只是感情好现横,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,196評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著阁最,像睡著了一般戒祠。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上速种,一...
    開封第一講書人閱讀 52,793評論 1 314
  • 那天姜盈,我揣著相機(jī)與錄音,去河邊找鬼配阵。 笑死馏颂,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的棋傍。 我是一名探鬼主播救拉,決...
    沈念sama閱讀 41,221評論 3 423
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼瘫拣!你這毒婦竟也來了亿絮?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,174評論 0 277
  • 序言:老撾萬榮一對情侶失蹤麸拄,失蹤者是張志新(化名)和其女友劉穎派昧,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體拢切,經(jīng)...
    沈念sama閱讀 46,699評論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蒂萎,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,770評論 3 343
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了淮椰。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片五慈。...
    茶點(diǎn)故事閱讀 40,918評論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡纳寂,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出泻拦,到底是詐尸還是另有隱情毙芜,我是刑警寧澤,帶...
    沈念sama閱讀 36,573評論 5 351
  • 正文 年R本政府宣布聪轿,位于F島的核電站爷肝,受9級特大地震影響猾浦,放射性物質(zhì)發(fā)生泄漏陆错。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,255評論 3 336
  • 文/蒙蒙 一金赦、第九天 我趴在偏房一處隱蔽的房頂上張望音瓷。 院中可真熱鬧,春花似錦夹抗、人聲如沸绳慎。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,749評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽杏愤。三九已至,卻和暖如春已脓,著一層夾襖步出監(jiān)牢的瞬間珊楼,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,862評論 1 274
  • 我被黑心中介騙來泰國打工度液, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留厕宗,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,364評論 3 379
  • 正文 我出身青樓堕担,卻偏偏與公主長得像已慢,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子霹购,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,926評論 2 361

推薦閱讀更多精彩內(nèi)容