vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#

https://www.vbarchiv.net
Rubrik: Datenbanken · ADO.NET Allgemein   |   VB-Versionen: VB.NET19.12.07
Datenbank-Inhalt schnell kopieren (VB 2005)

Mit der ADO.NET 2.0 SQLBulkCopy-Klasse lassen sich große Datenmengen schnell von einer Tabelle in eine andere Tabelle kopieren.

Autor:   Dieter OtterBewertung:  Views:  19.135 
www.tools4vb.deSystem:  WinNT, Win2k, WinXP, Win7, Win8, Win10, Win11kein Beispielprojekt 

Sollen große Datenmengen aus einer Datenbank-Tabelle in eine zweite Datenbank-Tabelle kopiert werden (bspw. auch als Backup-Variante) können Sie hierfür die neue SQLBulkCopy-Klasse in ADO.NET 2.0 verwenden. Die Handhabung ist hierbei wirklich sehr einfach:

  1. Verbindung zur Quell- und Ziel-Datenbank herstellen
  2. via DataReader die gewünschten Daten aus der Quell-Tabelle lesen
  3. via SQLBulkCopy alle selektierten Daten in die Ziel-Tabelle speichern
  4. Trennen der Datenbank-Verbindungen

' Connection-String für Quelle
Dim sConnSrc As String = "Persist Security Info=True;" & _
  "User ID=sa;" & _
  "Password=xxxx;" & _
  "Initial Catalog=TESTDB;" & _
  "Data Source=LOCALHOST;"
 
' Connection-String für Ziel
Dim sConnDest As String = "Persist Security Info=True;" & _
  "User ID=sa;" & _
  "Password=xxxx;" & _
  "Initial Catalog=TESTNEW;" & _
  "Data Source=LOCALHOST;"
 
' SQL-Connection-Objekte erstellen
Dim oConnSource As New SqlConnection(sConnSrc)
Dim oConnDest As New SqlConnection(sConnDest)
 
' Verbindungen zur Quell- und Ziel-Datenbank öffnen
oConnSource.Open()
oConnDest.Open()
 
' SQL-Befehl zum Selektieren aller Daten aus der Quell-Tabelle 
Dim oCommand As New SqlCommand("SELECT * FROM dbo.Table_1", oConnSource)
 
' alle Daten in ein DataReader-Objekt einlesen
Dim oReader As SqlDataReader = oCommand.ExecuteReader
 
' SQLBulkCopy-Objekt erstellen
Dim oBulkCopy As New SqlBulkCopy(oConnDest)
With oBulkCopy
  ' Ziel-Tabelle festlegen, in die die Daten gespeichert werden sollen
  .DestinationTableName = "dbo.Table_1"
 
  ' jetzt alle Daten aus dem DataReader in die Ziel-Tabelle schreiben
  .WriteToServer(oReader)
End With
 
' Verbindungen schließen
oConnSource.Close()
oConnDest.Close()



Anzeige

Kauftipp Unser Dauerbrenner!Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv  Vol.6

Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv!
- nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten
- Symbol-Galerie mit mehr als 3.200 Icons im modernen Look
Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m.
 
 
Copyright ©2000-2024 vb@rchiv Dieter OtterAlle Rechte vorbehalten.


Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.