欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python操作MySQL 模擬簡(jiǎn)單銀行轉(zhuǎn)賬操作

 更新時(shí)間:2017年09月27日 11:17:53   作者:幸福清風(fēng)  
這篇文章主要介紹了python操作MySQL 模擬簡(jiǎn)單銀行轉(zhuǎn)賬操作,需要的朋友可以參考下

一、基礎(chǔ)知識(shí)

1、MySQL-python的安裝

下載,然后 pip install 安裝包

2、python編寫(xiě)通用數(shù)據(jù)庫(kù)程序的API規(guī)范

(1)、數(shù)據(jù)庫(kù)連接對(duì)象 connection,建立python客戶(hù)端與數(shù)據(jù)庫(kù)的網(wǎng)絡(luò)連接,創(chuàng)建方法為 MySQLdb.Connect(參數(shù))

     參數(shù)有六個(gè):     host(MySQL服務(wù)器地址,一般本地為127.0.0.1)

                            port(MySQL服務(wù)器端口號(hào))
                            user(用戶(hù)名)
                            passwd(密碼)
                            db(數(shù)據(jù)庫(kù)名稱(chēng))
                            charset(連接編碼)

     connection的方法: cursor()使用該連接并返回游標(biāo)

                                      commit()提交當(dāng)前事務(wù)
                                      rollback()回滾當(dāng)前事務(wù)
                                      close()關(guān)閉連接

(2)、數(shù)據(jù)庫(kù)游標(biāo)對(duì)象cursor,用于執(zhí)行查詢(xún)和獲取結(jié)果

    方法:execute(op[,args])執(zhí)行一個(gè)數(shù)據(jù)庫(kù)查詢(xún) 和 命令

              fetchone()取得結(jié)果集的下一行
              fetchmany(size)獲取結(jié)果集的下幾行
              fetchall()獲取結(jié)果集中剩下的所有行
              rowcount 最近一次execute返回?cái)?shù)據(jù)的行數(shù)或影響行數(shù)
              close()關(guān)閉游標(biāo)對(duì)象

connection與cursor:connection相當(dāng)于python與MySQL之間的路,而cursor相當(dāng)于路上的運(yùn)輸車(chē)來(lái)傳送命令與結(jié)果。                     

3、簡(jiǎn)單命令:

select  查詢(xún)數(shù)據(jù):sql="select * from 表名 所查項(xiàng)目"
insert  插入數(shù)據(jù):sql=“insert into 表名  所插項(xiàng)目”
update 更改數(shù)據(jù): sql=“updata 表名 set  所改項(xiàng)目 ”
delete 刪除數(shù)據(jù): sql=“delete from 表名 所刪項(xiàng)目”
where也是sql命令的關(guān)鍵存在,通常是  where 表頭=列名 來(lái)定位那一列

4、事務(wù)

訪問(wèn)和更新數(shù)據(jù)庫(kù)的一個(gè)程序執(zhí)行單元,所執(zhí)行的命令,都可以稱(chēng)為事務(wù)

具有原子性,一致性,隔離性,持久性

事務(wù)執(zhí)行:

     conn.commit() 正常結(jié)束事務(wù)
     conn.rollback() 異常結(jié)束事務(wù),對(duì)事務(wù)進(jìn)行回滾,若程序執(zhí)行單元中的連續(xù)的操作在進(jìn)行中出錯(cuò),之前的操作還原。

簡(jiǎn)單操作過(guò)程:    開(kāi)始 → 創(chuàng)建connection →獲取cursor → 程序執(zhí)行單元 → 關(guān)閉cursor → 關(guān)閉connection → 結(jié)束

二、模擬銀行轉(zhuǎn)賬系統(tǒng)代碼

#coding=utf-8 
import sys 
import MySQLdb 
''''' 
python操作MySQL數(shù)據(jù)庫(kù),模擬銀行轉(zhuǎn)賬 
''' 
class Trans_for_Money(object): 
 #初始化 類(lèi) 
 def __init__(self,conn): 
  self.conn = conn 
 #### 1、檢查所輸入的賬號(hào)是否存在 #### 
 def check_acct_available(self,source_acctid): 
  #使用與數(shù)據(jù)庫(kù)的鏈接并返回游標(biāo) 
  cursor=self.conn.cursor() 
  try: 
   #數(shù)據(jù)庫(kù)命令 
   sql="select * from tr_money where acctid=%s" %source_acctid 
   #執(zhí)行命令 
   cursor.execute(sql) 
   #為方便觀察執(zhí)行過(guò)程 
   print "check_acct_available:" + sql 
   #講結(jié)果集放入變量result中,若result不等于1,則沒(méi)有這個(gè)賬號(hào),輸出異常 
   result=cursor.fetchall() 
   if len(result)!=1: 
    raise Exception("賬號(hào)%s不存在" %source_acctid) 
  finally: 
   #若過(guò)程出現(xiàn)問(wèn)題,仍需要關(guān)閉游標(biāo)對(duì)象 
   cursor.close() 
 #### 2、檢查減款人余額是否充足,方法與上一個(gè)函數(shù)一樣,只是多加了一個(gè)money參數(shù) ### 
 def has_enough_money(self,source_acctid,money): 
  cursor=self.conn.cursor() 
  try: 
   sql="select * from tr_money where acctid=%s and money>%s" %(source_acctid,money) 
   cursor.execute(sql) 
   print "has_enough_money:" + sql 
   result=cursor.fetchall() 
   if len(result)!=1: 
    raise Exception("賬號(hào)%s余額不足" %source_acctid) 
  finally: 
   cursor.close() 
 #### 3、減款操作 ### 
 def reduce_money(self,source_acctid,money): 
  cursor=self.conn.cursor() 
  try: 
   #數(shù)據(jù)庫(kù)命令,減去對(duì)應(yīng)減款人的金額數(shù) 
   sql="update tr_money set money=money-%s where acctid=%s" %(money,source_acctid) 
   cursor.execute(sql) 
   print "reduce_money:" + sql 
   #操作的execute()數(shù)據(jù)行數(shù)不等于1則減款失敗 
   if cursor.rowcount!=1: 
    raise Exception("賬號(hào)%s減款失敗" %source_acctid) 
  finally: 
   cursor.close() 
 #### 4、收款操作,與減款方法相同 ### 
 def add_money(self,target_acctid,money): 
  cursor=self.conn.cursor() 
  try: 
   sql="update tr_money set money=money+%s where acctid =%s" %(money,target_acctid) 
   cursor.execute(sql) 
   print "add_money:" + sql 
   if cursor.rowcount!=1: 
    raise Exception("賬號(hào)%s收款失敗" %target_acctid) 
  finally: 
   cursor.close() 
 #### 5、分別傳入?yún)?shù),代入上方函數(shù),執(zhí)行操作 ### 
 def trans_for(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) 
   #提交當(dāng)前事務(wù) 
   self.conn.commit() 
  except Exception as e: 
   #若出錯(cuò),回滾當(dāng)前事務(wù) 
   self.conn.rollback() 
   raise e 
if __name__=="__main__": 
 # source_acctid=sys.argv[1] 
 # target_acctid=sys.argv[2] 
 # money=sys.argv[3] 
 #建立與數(shù)據(jù)庫(kù)的鏈接 
 conn = MySQLdb.Connect( 
       host='127.0.0.1', 
       port=3306, 
       user='root', 
       passwd='12345678', 
       db='tt', 
       charset='utf8' 
       ) 
 #手動(dòng)輸入減款人、收款人、轉(zhuǎn)款數(shù) 
 source_acctid=raw_input("請(qǐng)輸入減款人: ") 
 target_acctid=raw_input("請(qǐng)輸入收款人: ") 
 money=raw_input("請(qǐng)輸入轉(zhuǎn)款數(shù): ") 
 #將參數(shù)傳入類(lèi)中 
 tr_money=Trans_for_Money(conn) 
 try: 
  tr_money.trans_for(source_acctid,target_acctid,money) 
 except Exception as e: 
  print"出現(xiàn)問(wèn)題:"+str(e) 
 finally: 
  conn.close() 
  #關(guān)閉鏈接 

三、問(wèn)題解決

1、sys.argv[ ] 

因?yàn)榻虒W(xué)視頻中用的IDE是MyEclipse,最后用run.Configuration 輸入?yún)?shù),而我用的是pycharm,表示笨的找不到還是其實(shí)它沒(méi)有!

所以選擇用raw_input() 在執(zhí)行過(guò)程中輸入?yún)?shù)

其實(shí)有去了解sys.argv[ ],但還是懂不太清楚。

2、  mysql_exceptions.IntegrityError: (1062, "Duplicate entry '7' for key 'PRIMARY'")

這個(gè)錯(cuò)誤表示你所要插入的數(shù)據(jù)已經(jīng)存在,最好去觀察一下數(shù)據(jù)庫(kù)的數(shù)據(jù)與自己的程序操作是否有矛盾

3、MySql 建表或輸入數(shù)值時(shí)出錯(cuò):1170-BLOB/TEXT column‘name'used in key specification without a key length

錯(cuò)誤信息為BLOB或者TEXT字段使用了未指定鍵值長(zhǎng)度的鍵

解決方法:設(shè)置其他為主鍵  或   將數(shù)據(jù)形式改為varchar

具體解釋網(wǎng)址:http://myhblog1989.blog.163.com/blog/static/183225376201110875818884/

4、TypeError: 'post' is an invalid keyword argument for this function

錯(cuò)誤原因:TypeError: “post”是這個(gè)函數(shù)的無(wú)效參數(shù)

這個(gè)問(wèn)題錯(cuò)的很無(wú)語(yǔ),一時(shí)腦子進(jìn)水把 “port”=3306 寫(xiě)成了“post”=‘3306'

5、1054, "Unknown column 'acctid' in 'where clause'

錯(cuò)誤原因:在where子句中找不到“acctid”列

呵呵,上個(gè)錯(cuò)誤腦子進(jìn)的水沒(méi)排出來(lái),把表頭寫(xiě)錯(cuò)了…………

6、另外,還有一個(gè)錯(cuò)誤是手動(dòng)輸入的減款,收款人設(shè)為字母或漢字時(shí)找不到

可能是我代碼或數(shù)據(jù)庫(kù)建表時(shí)的設(shè)定問(wèn)題,表示在字符轉(zhuǎn)換和數(shù)據(jù)庫(kù)這方面還是小白一枚,繼續(xù)奮斗吧!

7、MySQL數(shù)據(jù)庫(kù)的啟動(dòng)

計(jì)算機(jī) → 右鍵 → 管理 → 服務(wù)和應(yīng)用程序 → 服務(wù) → 找到MySQL → 右鍵啟動(dòng)

四、具體執(zhí)行顯示

1、數(shù)據(jù)庫(kù) tr_money 表的初始狀態(tài)

2、代碼執(zhí)行,輸入減款人,收款人,轉(zhuǎn)款數(shù)額

3、執(zhí)行,結(jié)果出現(xiàn)代碼中特意 print 的操作進(jìn)程顯示

4、數(shù)據(jù)庫(kù) tr_money 表執(zhí)行后狀態(tài)

總結(jié)

以上所述是小編給大家介紹的python 操作mysql 模擬銀行轉(zhuǎn)賬,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • python中with的具體用法

    python中with的具體用法

    本文主要介紹了python中with的基本使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • 簡(jiǎn)單了解python 生成器 列表推導(dǎo)式 生成器表達(dá)式

    簡(jiǎn)單了解python 生成器 列表推導(dǎo)式 生成器表達(dá)式

    這篇文章主要介紹了簡(jiǎn)單了解python 生成器 列表推導(dǎo)式 生成器表達(dá)式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-08-08
  • Python實(shí)現(xiàn)微信中找回好友、群聊用戶(hù)撤回的消息功能示例

    Python實(shí)現(xiàn)微信中找回好友、群聊用戶(hù)撤回的消息功能示例

    這篇文章主要介紹了Python實(shí)現(xiàn)微信中找回好友、群聊用戶(hù)撤回的消息功能,結(jié)合實(shí)例形式分析了Python基于微信itchat模塊實(shí)現(xiàn)針對(duì)撤回消息的查看功能相關(guān)操作技巧,需要的朋友可以參考下
    2019-08-08
  • python numpy數(shù)組中的復(fù)制知識(shí)解析

    python numpy數(shù)組中的復(fù)制知識(shí)解析

    這篇文章主要介紹了python numpy數(shù)組中的復(fù)制知識(shí)解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-02-02
  • Numpy之random函數(shù)使用學(xué)習(xí)

    Numpy之random函數(shù)使用學(xué)習(xí)

    這篇文章主要介紹了Numpy之random使用學(xué)習(xí),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-01-01
  • Python PyQt5實(shí)現(xiàn)的簡(jiǎn)易計(jì)算器功能示例

    Python PyQt5實(shí)現(xiàn)的簡(jiǎn)易計(jì)算器功能示例

    這篇文章主要介紹了Python PyQt5實(shí)現(xiàn)的簡(jiǎn)易計(jì)算器功能,涉及Python PyQt5事件響應(yīng)及數(shù)學(xué)運(yùn)算等相關(guān)操作技巧,需要的朋友可以參考下
    2017-08-08
  • Python面向?qū)ο缶幊讨畢^(qū)間的插入詳解

    Python面向?qū)ο缶幊讨畢^(qū)間的插入詳解

    這篇文章主要為大家詳細(xì)介紹了Python面向?qū)ο缶幊虒?shí)例教程中的區(qū)間的插入,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Python有一定幫助,需要的可以參考一下
    2022-08-08
  • Python教程使用Chord包實(shí)現(xiàn)炫彩弦圖示例

    Python教程使用Chord包實(shí)現(xiàn)炫彩弦圖示例

    在可視化中,有時(shí)候會(huì)使用到弦圖(Chord Diagram)來(lái)表示事物之間關(guān)系,本篇文章教大家如何使用Chord包實(shí)現(xiàn)炫彩弦圖,有需要的朋友可以借鑒參考下,希望大家多多進(jìn)步,早日升職加薪
    2021-09-09
  • python pydoc生成API文檔的實(shí)現(xiàn)

    python pydoc生成API文檔的實(shí)現(xiàn)

    pydoc?模塊會(huì)根據(jù) Python 模塊來(lái)自動(dòng)生成文檔,本文主要介紹了python pydoc生成API文檔的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-12-12
  • Python連接到PostgreSQL數(shù)據(jù)庫(kù)的方法詳解

    Python連接到PostgreSQL數(shù)據(jù)庫(kù)的方法詳解

    顧名思義,PostgreSQL?是一款為高效管理數(shù)據(jù)庫(kù)系統(tǒng)而創(chuàng)建的?SQL?系統(tǒng)軟件,這篇文章主要為大家詳細(xì)介紹了創(chuàng)建與?PostgreSQL?上的數(shù)據(jù)庫(kù)的連接的過(guò)程,需要的小伙伴可以了解下
    2023-10-10

最新評(píng)論