亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

滿足第一個條件后執行第二個更新語句

滿足第一個條件后執行第二個更新語句

慕婉清6462132 2022-07-05 17:42:33
我正在嘗試實現一個用戶將錢轉移到另一個帳戶的銀行交易。但是我的 sql 語句遇到了問題。我已經聲明了一個條件來檢查被轉移的金額是否小于余額。如果滿足條件,那么只有我在更新表格。但是,即使發件人帳戶中的值根本沒有改變,我的第二個更新接收者帳戶的表也會更新。這是我正在使用的代碼:con = sqlite3.connect('Bank.db')con.isolation_level = Nonecon.execute("begin")cursorObj = con.cursor()amnt = 120000acc_no = 123456try:    cursorObj.execute("UPDATE transfer SET balance = balance - (?) where (account_no = (?) and balance > (?))", (amnt, acc_no, amnt))    cursorObj.execute("UPDATE transfer SET balance = balance + (?) where account_no = 847425", (amnt, ))    cursorObj.execute("commit")except con.Error:    print("failed!")    cursorObj.execute("rollback")cursorObj.execute("SELECT balance FROM transfer")result = cursorObj.fetchall()print(result)[![enter image description here][1]][1]
查看完整描述

1 回答

?
有只小跳蛙

TA貢獻1824條經驗 獲得超8個贊

一種方法是首先從發送用戶那里檢索余額,類似于


sending_user_balance = "SELECT balance FROM table WHERE account_no = <account_no>"

并且僅當用戶余額等于或大于發送的金額時才發送:


if sending_user_balance > amount:

    cursorObj.execute("UPDATE transfer SET balance = balance - (?) where (account_no = (?))", (amnt, acc_no, amnt))

    cursorObj.execute("UPDATE transfer SET balance = balance + (?) where account_no = 847425", (amnt, ))

    cursorObj.execute("commit")

當然,現在你可以放棄了,and balance >因為你已經檢查過了。


查看完整回答
反對 回復 2022-07-05
  • 1 回答
  • 0 關注
  • 167 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號