Heim Backend-Entwicklung XML/RSS-Tutorial Verwenden von XML und SQL 2000 zum Verwalten gespeicherter Prozeduraufrufe

Verwenden von XML und SQL 2000 zum Verwalten gespeicherter Prozeduraufrufe

Mar 04, 2017 pm 05:18 PM

Das Erstellen mehrerer gespeicherter Prozeduren (Stored PROcedure) mit unterschiedlichen Parametern zur Erledigung derselben Aufgabe ist immer eine große Belastung. Die Verwendung von XML-Strings zum Senden von Parametern an Ihre gespeicherten Prozeduren kann diese Aufgabe vereinfachen; dadurch wird auch das Design von COM-Komponenten einfacher.

Dies erreichen Sie, indem Sie Ihre Parameter als XML-String übergeben, das XML analysieren, um die benötigten Daten abzurufen, und dann mit der Implementierung der Funktionalität fortfahren, die Sie integrieren müssen. Sie können nicht nur einige Parameter über XML abrufen, sondern auch Abfragen für das von XML erstellte DOM-Dokument ausführen, um mehrere gespeicherte Prozeduren zu kapseln. Ich werde einige Beispiele dafür liefern, wie dies erreicht werden kann, und jedes Beispiel kurz beschreiben.

In diesem Beispiel werde ich mehrere Parameter übergeben, um das Namensfeld in einer Kundentabelle zu aktualisieren. Das XML wird analysiert, um die Kunden-ID (Identitätsspalte) und das neue Namensfeld zu erhalten. Der XML-String, den ich an die Prozedur übergebe, sieht folgendermaßen aus:

<root><Customer><customerid>3</customerid><name>Acme
 Inc.</name></Customer></root>
Nach dem Login kopieren

Das zu erstellende Speicherfeld sieht folgendermaßen aus:

CREATE PROCEDURE update_Customer (@xmldatavarchar(8000)) ASDECLARE @customeridintDECLARE @customernamevarchar(50)DECLARE @xmldata_idint
EXEC sp_xml_preparedocument @xmldata_id OUTPUT, @xmldata, &#39;&#39;
SELECT @customerid = customerid, @customername = [name] FROM OPENXML(@xmldata_id, &#39;//Customer&#39;, 2) WITH (customeridint, [name] varchar(50))
EXEC sp_xml_removedocument @xmldata_id
UPDATE Customer SET Customer.[name] = ISNULL(@customername, Customer.[name])WHERE Customer.tblID = @customerid
Nach dem Login kopieren

Dieser Prozess wird zuerst deklariert dass die von uns verwendeten Variablen relevante Informationen speichern. Danach wird das DOM-Dokument geöffnet und ein „Handle“ als erster Parameter des sp_xml_preparedocument-Aufrufs zurückgegeben.

Das zweite Argument dieses Aufrufs ist die XML-Quelldatei für das neue DOM-Dokument. Dieses „Handle“ wird verwendet, um bei OPENXML-Aufrufen Informationen aus dem DOM abzufragen. Der zweite Parameter des OPENXML-Aufrufs ist eine Xpath-Zuordnung der übergeordneten Knoten, die die auszuführenden Daten enthalten.


Der dritte Parameter (2) gibt an, dass eine elementzentrierte Zuordnung verwendet wird. Die WITH-Klausel stellt ein Rowset-Format für die analysierten Daten bereit, und der Aufruf von sp_xml_removedocument löscht die Quelldatei des DOM-Dokuments.

Im folgenden Beispiel übergebe ich eine Reihe von Benutzer-IDs, um mehrere Datenspalten zu löschen. Das Folgende ist der Inhalt der XML-Zeichenfolge:

<root><Customer><customerid>1</customerid></Customer><Customer><customerid>
2</customerid></Customer><Customer><customerid>3</customerid></Customer>
</root>
Nach dem Login kopieren

Die entsprechende gespeicherte Prozedur sieht wie folgt aus:

. . .
EXEC sp_xml_preparedocument @xml_id OUTPUT, @xmldata, &#39;&#39;
DELETE FROM Customer WHERE Customer.tblID IN (SELECT customerid FROM OPENXML(@xmldata_id, &#39;//Customer&#39;, 2) WITH (customeridint))
. . .
Nach dem Login kopieren


Ja Mit dieser gespeicherten Prozedur müssen Sie keine lange SQL-Abfragezeichenfolge mehr erstellen, um sie in ADO zu übergeben oder eine gespeicherte Prozedur mehrmals aufzurufen. Dadurch werden auch die Auswirkungen mehrerer Anrufe auf den Netzwerkverkehr eliminiert.

Wie Sie sehen, erleichtert Microsoft SQL 2000 den gesamten Prozess ein wenig. Bedenken Sie, dass der Nachteil dieses Ansatzes darin besteht, dass bei der Ausführung von XML-Aufgaben durch SQL 2000 das Senden von XML als Parameter auf 8.000 Zeichen begrenzt ist. Wie immer sollten Sie die Vorteile einer sorgfältigen Planung nicht außer Acht lassen.

Besuchen Sie die MSDN-Bibliothek, um weitere Informationen zu OPENXML, sp_xml_preparedocument und sp_xml_removedocument zu erhalten.

Das Obige ist der Inhalt der Verwendung von XML und SQL 2000 zum Verwalten gespeicherter Prozeduraufrufe. Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website (www.php.cn)!


Erklärung dieser Website
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

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)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Was ist der Unterschied zwischen HQL und SQL im Hibernate-Framework? Was ist der Unterschied zwischen HQL und SQL im Hibernate-Framework? Apr 17, 2024 pm 02:57 PM

HQL und SQL werden im Hibernate-Framework verglichen: HQL (1. Objektorientierte Syntax, 2. Datenbankunabhängige Abfragen, 3. Typsicherheit), während SQL die Datenbank direkt betreibt (1. Datenbankunabhängige Standards, 2. Komplexe ausführbare Datei). Abfragen und Datenmanipulation).

Kann ich eine XML-Datei mit PowerPoint öffnen? Kann ich eine XML-Datei mit PowerPoint öffnen? Feb 19, 2024 pm 09:06 PM

Können XML-Dateien mit PPT geöffnet werden? XML, Extensible Markup Language (Extensible Markup Language), ist eine universelle Auszeichnungssprache, die häufig im Datenaustausch und in der Datenspeicherung verwendet wird. Im Vergleich zu HTML ist XML flexibler und kann eigene Tags und Datenstrukturen definieren, wodurch die Speicherung und der Austausch von Daten komfortabler und einheitlicher werden. PPT oder PowerPoint ist eine von Microsoft entwickelte Software zum Erstellen von Präsentationen. Es bietet eine umfassende Möglichkeit

Verwendung der Divisionsoperation in Oracle SQL Verwendung der Divisionsoperation in Oracle SQL Mar 10, 2024 pm 03:06 PM

„Verwendung der Divisionsoperation in OracleSQL“ In OracleSQL ist die Divisionsoperation eine der häufigsten mathematischen Operationen. Während der Datenabfrage und -verarbeitung können uns Divisionsoperationen dabei helfen, das Verhältnis zwischen Feldern zu berechnen oder die logische Beziehung zwischen bestimmten Werten abzuleiten. In diesem Artikel wird die Verwendung der Divisionsoperation in OracleSQL vorgestellt und spezifische Codebeispiele bereitgestellt. 1. Zwei Arten von Divisionsoperationen in OracleSQL In OracleSQL können Divisionsoperationen auf zwei verschiedene Arten durchgeführt werden.

Vergleich und Unterschiede der SQL-Syntax zwischen Oracle und DB2 Vergleich und Unterschiede der SQL-Syntax zwischen Oracle und DB2 Mar 11, 2024 pm 12:09 PM

Oracle und DB2 sind zwei häufig verwendete relationale Datenbankverwaltungssysteme, die jeweils über ihre eigene, einzigartige SQL-Syntax und -Eigenschaften verfügen. In diesem Artikel werden die SQL-Syntax von Oracle und DB2 verglichen und unterschieden und spezifische Codebeispiele bereitgestellt. Datenbankverbindung Verwenden Sie in Oracle die folgende Anweisung, um eine Verbindung zur Datenbank herzustellen: CONNECTusername/password@database. In DB2 lautet die Anweisung zum Herstellen einer Verbindung zur Datenbank wie folgt: CONNECTTOdataba

Ausführliche Erläuterung der Funktion „Tag festlegen' in den dynamischen SQL-Tags von MyBatis Ausführliche Erläuterung der Funktion „Tag festlegen' in den dynamischen SQL-Tags von MyBatis Feb 26, 2024 pm 07:48 PM

Interpretation der dynamischen SQL-Tags von MyBatis: Detaillierte Erläuterung der Verwendung von Set-Tags. MyBatis ist ein hervorragendes Persistenzschicht-Framework. Es bietet eine Fülle dynamischer SQL-Tags und kann Datenbankoperationsanweisungen flexibel erstellen. Unter anderem wird das Set-Tag zum Generieren der SET-Klausel in der UPDATE-Anweisung verwendet, die sehr häufig bei Aktualisierungsvorgängen verwendet wird. In diesem Artikel wird die Verwendung des Set-Tags in MyBatis ausführlich erläutert und seine Funktionalität anhand spezifischer Codebeispiele demonstriert. Was ist Set-Tag? Set-Tag wird in MyBati verwendet

Schritte und Vorsichtsmaßnahmen für die Implementierung von Batch-Updates mithilfe gespeicherter Oracle-Prozeduren Schritte und Vorsichtsmaßnahmen für die Implementierung von Batch-Updates mithilfe gespeicherter Oracle-Prozeduren Mar 08, 2024 pm 04:12 PM

Titel: Schritte und Vorsichtsmaßnahmen für die Implementierung von Stapelaktualisierungen durch gespeicherte Oracle-Prozeduren. In Oracle-Datenbanken handelt es sich bei gespeicherten Prozeduren um eine Reihe von SQL-Anweisungen, die dazu dienen, die Datenbankleistung zu verbessern, Code wiederzuverwenden und die Sicherheit zu erhöhen. Gespeicherte Prozeduren können zum Aktualisieren von Daten in Stapeln verwendet werden. In diesem Artikel wird erläutert, wie gespeicherte Oracle-Prozeduren zum Implementieren von Batch-Updates verwendet werden, und es werden spezifische Codebeispiele bereitgestellt. Schritt 1: Erstellen Sie eine gespeicherte Prozedur. Zuerst müssen wir eine gespeicherte Prozedur erstellen, um Stapelaktualisierungsvorgänge zu implementieren. Im Folgenden erfahren Sie, wie Sie eine gespeicherte Prozedur erstellen

So beheben Sie den 5120-Fehler in SQL So beheben Sie den 5120-Fehler in SQL Mar 06, 2024 pm 04:33 PM

Lösung: 1. Überprüfen Sie, ob der angemeldete Benutzer über ausreichende Berechtigungen zum Zugriff auf oder zum Betrieb der Datenbank verfügt, und stellen Sie sicher, dass der Benutzer über die richtigen Berechtigungen verfügt. 2. Überprüfen Sie, ob das Konto des SQL Server-Dienstes über die Berechtigung zum Zugriff auf die angegebene Datei verfügt Ordner und stellen Sie sicher, dass das Konto über ausreichende Berechtigungen zum Lesen und Schreiben der Datei oder des Ordners verfügt. 3. Überprüfen Sie, ob die angegebene Datenbankdatei von anderen Prozessen geöffnet oder gesperrt wurde. Versuchen Sie, die Datei zu schließen oder freizugeben, und führen Sie die Abfrage erneut aus . Versuchen Sie es als Administrator. Führen Sie Management Studio aus als usw.

Datenbanktechnologie-Wettbewerb: Was sind die Unterschiede zwischen Oracle und SQL? Datenbanktechnologie-Wettbewerb: Was sind die Unterschiede zwischen Oracle und SQL? Mar 09, 2024 am 08:30 AM

Datenbanktechnologie-Wettbewerb: Was sind die Unterschiede zwischen Oracle und SQL? Im Datenbankbereich sind Oracle und SQL Server zwei hoch angesehene relationale Datenbankverwaltungssysteme. Obwohl beide zur Kategorie der relationalen Datenbanken gehören, gibt es viele Unterschiede zwischen ihnen. In diesem Artikel befassen wir uns mit den Unterschieden zwischen Oracle und SQL Server sowie deren Funktionen und Vorteilen in praktischen Anwendungen. Zunächst einmal gibt es Unterschiede in der Syntax zwischen Oracle und SQL Server.

See all articles