suchen
HeimBackend-EntwicklungPython-TutorialPython implementiert eine einfache Banküberweisungsoperationsmethode

Vorwort

Bei der Entwicklung eines Anwendungssystems sind im Allgemeinen von oben nach unten vier Komponenten erforderlich: Client - Geschäftslogikschicht - Datenzugriffsschicht - Datenbank, wobei die Datenzugriffsschicht eine unterste Schicht und Kerntechnologie ist. Und in der tatsächlichen Entwicklung ist der Betrieb der Datenbank, also der Datenzugriffsschicht, in anderen Sprachen verschachtelt, was den Kern der Programmierung darstellt. Dieser Artikel konzentriert sich auf die Python-Sprache, dh auf den Betrieb der Datenbank über Python, um einfache Banküberweisungsvorgänge zu implementieren.

Tools

Python stellt die Python-DB-API bereit, um den Betrieb der Datenbank zu vereinheitlichen und die Schnittstelle für den Zugriff auf die Datenbank zu standardisieren war sehr verwirrend. Unterschiedliche Datenbanken erfordern unterschiedliche Bedienoberflächen, daher bietet diese Schnittstelle großen Komfort. Während bestimmter Vorgänge müssen wir die Datenbank und andere logische Python-Codes, die Datenbankverbindungsobjektverbindung zum Herstellen der Verbindung und den Datenbankinteraktionsobjektcursor zum „Transportieren“ von Daten betreiben. Für die Datenbankausnahmeklasse Exceptions ist ein robustes System unverzichtbar. Der gesamte Prozess des Zugriffs auf die Datenbank ist wie folgt:

Python implementiert eine einfache Banküberweisungsoperationsmethode

Als nächstes stellen wir die beiden Hauptobjekte vor:

Verbindung: Datenbankverbindungsobjekt, herstellen Python-Client und Datenbank-Netzwerkverbindung.
Erstellungsmethode: MySQLdb.connect(), einschließlich Hauptmitgliedsmethoden:
cursor(): Verwenden Sie die Verbindung, um einen Cursor zu erstellen und zurückzugeben
commit(): Senden Sie die aktuelle Transaktion
rollback() : Zurück Rollen Sie die aktuelle Transaktion
close(), um die Verbindung zu schließen
cursor: Cursorobjekt, das zum Ausführen von Abfragen und zum Erhalten von Ergebnissen verwendet wird. Die wichtigsten vom Cursorobjekt unterstützten Methoden sind wie folgt:
execute(). : SQL-Anweisungen ausführen und die Ergebnisse aus der Datenbank abrufen. Zum Client gelangen
fetchone(): Die nächste Zeile der Ergebnismenge abrufen
fetchmany(size): Die nächste Zeile der Ergebnismenge abrufen
fetchall(): Alle verbleibenden Zeilen in der Ergebnismenge abrufen
rowcount: Die Anzahl der Datenzeilen, die von der letzten Ausführung zurückgegeben wurden
close(): Das Cursorobjekt schließen
Ein Schlüsselbegriff wird in erwähnt die obige Methode: Transaktion Was ist eine Transaktion? Es handelt sich um eine Programmausführungseinheit, die auf Daten zugreift und diese aktualisiert. Sie ist eine Sammlung vieler Vorgänge und weist vier Merkmale auf:

Atomizität: Alle in den Dingen enthaltenen Vorgänge werden entweder ausgeführt oder keine davon wird konsistent ausgeführt Persistenz: Eine Transaktion muss die Datenbank von einem konsistenten Zustand in einen anderen Konsistenzzustand ändern.
Isolationstyp: Die Ausführung einer Transaktion wird nicht durch andere Transaktionen beeinträchtigt.
Persistenz: Sobald eine Transaktion festgeschrieben wird, werden ihre Änderungen in der Datenbank vorgenommen sind dauerhaft Die oben genannten Merkmale der
-Transaktion sind für uns der Schlüssel zum Abschluss des Banküberweisungsvorgangs.

Spezifische Umsetzung

Wie nutzen wir Transaktionen in der Entwicklung?

Automatisches Commit ausschalten()

Transaktion normal beenden: conn.commit(),
Transaktion abnormal beenden: conn.rollback()
Im Banküberweisungssystem Folgendes Anforderungen müssen berücksichtigt werden: Wenn A beispielsweise Geld an B überweist und M-Geld vom Konto von A abgezogen wird, muss M-Geld auf das Konto von B hinzugefügt werden. Es kann nicht sein, dass A Geld abgezogen hat, aber B es nicht hinzugefügt hat Dass B Geld hinzugefügt und A es nicht reduziert hat, muss natürlich gültig sein, der Geldbetrag von M muss größer sein als der Betrag auf dem Konto von A. Daher müssen im spezifischen Entwurf die Reduzierung des Geldbetrags auf Konto A und die Erhöhung des Geldbetrags auf Konto B als eine Transaktion behandelt werden, die entweder gleichzeitig erfolgreich ist oder gemeinsam fehlschlägt. Schreiben Sie den Code entsprechend dieser Anforderung. Die Codekopie und die Datenbank lauten wie folgt. Geben Sie beim Ausführen des Codes 1, 2.100 ein. transfer_money) in der Parameterspalte.

Python implementiert eine einfache Banküberweisungsoperationsmethode

Die Logik des gesamten Codes lautet wie folgt: Stellen Sie zuerst eine Verbindung zur Datenbank her, führen Sie dann die Logik aus und trennen Sie dann die Datenbankverbindung. Die ausgeführte Logik umfasst die Überprüfung, ob die Konten beider Übertragungsparteien gültig sind und ob der Überweisungsbetrag gültig ist. Wenn der Kontostand des Übertragenden übersteigt, ändern sich die Kontobeträge beider Übertragungsparteien. Wenn die Transaktion normal endet, übertragen Sie die Änderung in die Datenbank, andernfalls setzen Sie sie zurück.

#coding:utf-8
import sys
import MySQLdb
class TransferMoney():
def __init__(self, conn):
self.conn = conn
def transfer(self, src, target, money):
try:
self.check_acct_available(src)
self.check_acct_available(target)
self.has_enough_money(src, money)
self.reduce_money(src, money)
self.add_money(target, money)
self.conn.commit()
except Exception as e:
print e
self.conn.rollback()
def reduce_money(self, src, money):
cursor = self.conn.cursor()
try:
sql = "update account set money = money - %s where acctid = %s" %(money, src)
cursor.execute(sql)
print "reduce_money: " + sql
#rs = cursor.fetchall()
if cursor.rowcount != 1:
raise Exception("the account reduce money fail")
finally:
cursor.close()
def add_money(self, target, money):
cursor = self.conn.cursor()
try:
sql = "update account set money = money + %s where acctid = %s" %(money, target)
cursor.execute(sql)
print "add_money: " + sql
#rs = cursor.fetchall()
if cursor.rowcount != 1:
raise Exception("the account add money fail")
finally:
cursor.close()
def check_acct_available(self, accit):
cursor = self.conn.cursor()
try:
sql = "select * from account where acctid = %s" %accit
cursor.execute(sql)
print "check_acct_available: " + sql
rs = cursor.fetchall()
if len(rs) != 1:
raise Exception("the account %s is not exist" %accit)
finally:
cursor.close()
def has_enough_money(self, src, money):
cursor = self.conn.cursor()
try:
sql = "select * from account where acctid = %s and money >= %s " %(src, money)
cursor.execute(sql)
print "has_enough_money: " + sql
rs = cursor.fetchall()
if len(rs) != 1:
raise Exception("the account does not have enough money")
finally:
cursor.close()
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 = '******', passwd = '******', port = 3306, db = '******'
)
tr_money = TransferMoney(conn)
try:
tr_money.transfer(source_acctid, target_acctid, money)
except Exception as e:
print e
finally:
conn.close()

Zusammenfassung

Ein einfaches Banküberweisungssystem kann durch den Betrieb der Datenbank implementiert werden, also bei der Entwicklung Wir sollten unser Bestes geben, um das gesamte System nicht nur aus mehreren Komponenten zusammenzufügen, sondern um 1+1>2 zu erreichen.

Weitere verwandte Artikel zur Implementierung einer einfachen Banküberweisungsmethode in Python finden Sie auf der chinesischen PHP-Website!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Python lernen: Ist 2 Stunden tägliches Studium ausreichend?Python lernen: Ist 2 Stunden tägliches Studium ausreichend?Apr 18, 2025 am 12:22 AM

Ist es genug, um Python für zwei Stunden am Tag zu lernen? Es hängt von Ihren Zielen und Lernmethoden ab. 1) Entwickeln Sie einen klaren Lernplan, 2) Wählen Sie geeignete Lernressourcen und -methoden aus, 3) praktizieren und prüfen und konsolidieren Sie praktische Praxis und Überprüfung und konsolidieren Sie und Sie können die Grundkenntnisse und die erweiterten Funktionen von Python während dieser Zeit nach und nach beherrschen.

Python für die Webentwicklung: SchlüsselanwendungenPython für die Webentwicklung: SchlüsselanwendungenApr 18, 2025 am 12:20 AM

Zu den wichtigsten Anwendungen von Python in der Webentwicklung gehören die Verwendung von Django- und Flask -Frameworks, API -Entwicklung, Datenanalyse und Visualisierung, maschinelles Lernen und KI sowie Leistungsoptimierung. 1. Django und Flask Framework: Django eignet sich für die schnelle Entwicklung komplexer Anwendungen, und Flask eignet sich für kleine oder hochmobile Projekte. 2. API -Entwicklung: Verwenden Sie Flask oder Djangorestframework, um RESTFUFFUPI zu erstellen. 3. Datenanalyse und Visualisierung: Verwenden Sie Python, um Daten zu verarbeiten und über die Webschnittstelle anzuzeigen. 4. Maschinelles Lernen und KI: Python wird verwendet, um intelligente Webanwendungen zu erstellen. 5. Leistungsoptimierung: optimiert durch asynchrones Programmieren, Caching und Code

Python vs. C: Erforschung von Leistung und Effizienz erforschenPython vs. C: Erforschung von Leistung und Effizienz erforschenApr 18, 2025 am 12:20 AM

Python ist in der Entwicklungseffizienz besser als C, aber C ist in der Ausführungsleistung höher. 1. Pythons prägnante Syntax und reiche Bibliotheken verbessern die Entwicklungseffizienz. 2. Die Kompilierungsmerkmale von Compilation und die Hardwarekontrolle verbessern die Ausführungsleistung. Bei einer Auswahl müssen Sie die Entwicklungsgeschwindigkeit und die Ausführungseffizienz basierend auf den Projektanforderungen abwägen.

Python in Aktion: Beispiele in realer WeltPython in Aktion: Beispiele in realer WeltApr 18, 2025 am 12:18 AM

Zu den realen Anwendungen von Python gehören Datenanalysen, Webentwicklung, künstliche Intelligenz und Automatisierung. 1) In der Datenanalyse verwendet Python Pandas und Matplotlib, um Daten zu verarbeiten und zu visualisieren. 2) In der Webentwicklung vereinfachen Django und Flask Frameworks die Erstellung von Webanwendungen. 3) Auf dem Gebiet der künstlichen Intelligenz werden Tensorflow und Pytorch verwendet, um Modelle zu bauen und zu trainieren. 4) In Bezug auf die Automatisierung können Python -Skripte für Aufgaben wie das Kopieren von Dateien verwendet werden.

Pythons Hauptnutzung: ein umfassender ÜberblickPythons Hauptnutzung: ein umfassender ÜberblickApr 18, 2025 am 12:18 AM

Python wird häufig in den Bereichen Data Science, Web Development und Automation Scripting verwendet. 1) In der Datenwissenschaft vereinfacht Python die Datenverarbeitung und -analyse durch Bibliotheken wie Numpy und Pandas. 2) In der Webentwicklung ermöglichen die Django- und Flask -Frameworks Entwicklern, Anwendungen schnell zu erstellen. 3) In automatisierten Skripten machen Pythons Einfachheit und Standardbibliothek es ideal.

Der Hauptzweck von Python: Flexibilität und BenutzerfreundlichkeitDer Hauptzweck von Python: Flexibilität und BenutzerfreundlichkeitApr 17, 2025 am 12:14 AM

Die Flexibilität von Python spiegelt sich in Multi-Paradigm-Unterstützung und dynamischen Typsystemen wider, während eine einfache Syntax und eine reichhaltige Standardbibliothek stammt. 1. Flexibilität: Unterstützt objektorientierte, funktionale und prozedurale Programmierung und dynamische Typsysteme verbessern die Entwicklungseffizienz. 2. Benutzerfreundlichkeit: Die Grammatik liegt nahe an der natürlichen Sprache, die Standardbibliothek deckt eine breite Palette von Funktionen ab und vereinfacht den Entwicklungsprozess.

Python: Die Kraft der vielseitigen ProgrammierungPython: Die Kraft der vielseitigen ProgrammierungApr 17, 2025 am 12:09 AM

Python ist für seine Einfachheit und Kraft sehr beliebt, geeignet für alle Anforderungen von Anfängern bis hin zu fortgeschrittenen Entwicklern. Seine Vielseitigkeit spiegelt sich in: 1) leicht zu erlernen und benutzten, einfachen Syntax; 2) Reiche Bibliotheken und Frameworks wie Numpy, Pandas usw.; 3) plattformübergreifende Unterstützung, die auf einer Vielzahl von Betriebssystemen betrieben werden kann; 4) Geeignet für Skript- und Automatisierungsaufgaben zur Verbesserung der Arbeitseffizienz.

Python in 2 Stunden am Tag lernen: Ein praktischer LeitfadenPython in 2 Stunden am Tag lernen: Ein praktischer LeitfadenApr 17, 2025 am 12:05 AM

Ja, lernen Sie Python in zwei Stunden am Tag. 1. Entwickeln Sie einen angemessenen Studienplan, 2. Wählen Sie die richtigen Lernressourcen aus, 3. Konsolidieren Sie das durch die Praxis erlernte Wissen. Diese Schritte können Ihnen helfen, Python in kurzer Zeit zu meistern.

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Crossplay haben?
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

MinGW – Minimalistisches GNU für Windows

MinGW – Minimalistisches GNU für Windows

Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

WebStorm-Mac-Version

WebStorm-Mac-Version

Nützliche JavaScript-Entwicklungstools

Dreamweaver Mac

Dreamweaver Mac

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)