


Python 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:
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.
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.
#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!
Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



PHP und Python haben ihre eigenen Vor- und Nachteile, und die Wahl hängt von den Projektbedürfnissen und persönlichen Vorlieben ab. 1.PHP eignet sich für eine schnelle Entwicklung und Wartung großer Webanwendungen. 2. Python dominiert das Gebiet der Datenwissenschaft und des maschinellen Lernens.

Python und JavaScript haben ihre eigenen Vor- und Nachteile in Bezug auf Gemeinschaft, Bibliotheken und Ressourcen. 1) Die Python-Community ist freundlich und für Anfänger geeignet, aber die Front-End-Entwicklungsressourcen sind nicht so reich wie JavaScript. 2) Python ist leistungsstark in Bibliotheken für Datenwissenschaft und maschinelles Lernen, während JavaScript in Bibliotheken und Front-End-Entwicklungsbibliotheken und Frameworks besser ist. 3) Beide haben reichhaltige Lernressourcen, aber Python eignet sich zum Beginn der offiziellen Dokumente, während JavaScript mit Mdnwebdocs besser ist. Die Wahl sollte auf Projektbedürfnissen und persönlichen Interessen beruhen.

Im VS -Code können Sie das Programm im Terminal in den folgenden Schritten ausführen: Erstellen Sie den Code und öffnen Sie das integrierte Terminal, um sicherzustellen, dass das Codeverzeichnis mit dem Terminal Working -Verzeichnis übereinstimmt. Wählen Sie den Befehl aus, den Befehl ausführen, gemäß der Programmiersprache (z. B. Pythons Python your_file_name.py), um zu überprüfen, ob er erfolgreich ausgeführt wird, und Fehler auflösen. Verwenden Sie den Debugger, um die Debugging -Effizienz zu verbessern.

VS -Code kann zum Schreiben von Python verwendet werden und bietet viele Funktionen, die es zu einem idealen Werkzeug für die Entwicklung von Python -Anwendungen machen. Sie ermöglichen es Benutzern: Installation von Python -Erweiterungen, um Funktionen wie Code -Abschluss, Syntax -Hervorhebung und Debugging zu erhalten. Verwenden Sie den Debugger, um Code Schritt für Schritt zu verfolgen, Fehler zu finden und zu beheben. Integrieren Sie Git für die Versionskontrolle. Verwenden Sie Tools für die Codeformatierung, um die Codekonsistenz aufrechtzuerhalten. Verwenden Sie das Lining -Tool, um potenzielle Probleme im Voraus zu erkennen.

Docker verwendet Linux -Kernel -Funktionen, um eine effiziente und isolierte Anwendungsumgebung zu bieten. Sein Arbeitsprinzip lautet wie folgt: 1. Der Spiegel wird als schreibgeschützte Vorlage verwendet, die alles enthält, was Sie für die Ausführung der Anwendung benötigen. 2. Das Union File System (UnionFS) stapelt mehrere Dateisysteme, speichert nur die Unterschiede, speichert Platz und beschleunigt. 3. Der Daemon verwaltet die Spiegel und Container, und der Kunde verwendet sie für die Interaktion. 4. Namespaces und CGroups implementieren Container -Isolation und Ressourcenbeschränkungen; 5. Mehrere Netzwerkmodi unterstützen die Containerverbindung. Nur wenn Sie diese Kernkonzepte verstehen, können Sie Docker besser nutzen.

VS -Code -Erweiterungen stellen böswillige Risiken dar, wie das Verstecken von böswilligem Code, das Ausbeutetieren von Schwachstellen und das Masturbieren als legitime Erweiterungen. Zu den Methoden zur Identifizierung böswilliger Erweiterungen gehören: Überprüfung von Verlegern, Lesen von Kommentaren, Überprüfung von Code und Installation mit Vorsicht. Zu den Sicherheitsmaßnahmen gehören auch: Sicherheitsbewusstsein, gute Gewohnheiten, regelmäßige Updates und Antivirensoftware.

VS -Code kann unter Windows 8 ausgeführt werden, aber die Erfahrung ist möglicherweise nicht großartig. Stellen Sie zunächst sicher, dass das System auf den neuesten Patch aktualisiert wurde, und laden Sie dann das VS -Code -Installationspaket herunter, das der Systemarchitektur entspricht und sie wie aufgefordert installiert. Beachten Sie nach der Installation, dass einige Erweiterungen möglicherweise mit Windows 8 nicht kompatibel sind und nach alternativen Erweiterungen suchen oder neuere Windows -Systeme in einer virtuellen Maschine verwenden müssen. Installieren Sie die erforderlichen Erweiterungen, um zu überprüfen, ob sie ordnungsgemäß funktionieren. Obwohl VS -Code unter Windows 8 möglich ist, wird empfohlen, auf ein neueres Windows -System zu upgraden, um eine bessere Entwicklungserfahrung und Sicherheit zu erzielen.

Python zeichnet sich in Automatisierung, Skript und Aufgabenverwaltung aus. 1) Automatisierung: Die Sicherungssicherung wird durch Standardbibliotheken wie OS und Shutil realisiert. 2) Skriptschreiben: Verwenden Sie die PSUTIL -Bibliothek, um die Systemressourcen zu überwachen. 3) Aufgabenverwaltung: Verwenden Sie die Zeitplanbibliothek, um Aufgaben zu planen. Die Benutzerfreundlichkeit von Python und die Unterstützung der reichhaltigen Bibliothek machen es zum bevorzugten Werkzeug in diesen Bereichen.
