Solved

Quickest way to insert records from one db into another

Posted on 2006-10-20
10
213 Views
Last Modified: 2010-04-16
Hi,

I have a DataTable entitled "dtSource" from database 'A'.  I would like to push the data into database 'B'.  Both databases are SQL Server 2005 and both table schemas are the same.

I suppose I could loop through the rows like so:

string sql = "";
foreach(DataRow dr in dt.Rows)
{
    sql += "INSERT INTO...."
    sql += dr[0].ToString() + ", ";
    etc....
}

There has to be a faster and/or more of an elegant way of doing this.

Thanks
0
Comment
Question by:brdrok
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 4
  • 3
  • 3
10 Comments
 
LVL 12

Accepted Solution

by:
topdog770 earned 300 total points
ID: 17775093

foreach(DataRow dr in dt.Rows)
{
    myDestinationDataTable.ImportRow(dr);
}

Then you can use Update to populate the second database



0
 
LVL 12

Expert Comment

by:topdog770
ID: 17775098
Let me know if you would like a bit more detail or if this is just the nudge you were looking for
0
 
LVL 28

Expert Comment

by:strickdd
ID: 17775369
Just execute the following SQL

sql = "Insert INTO dbo.A.dtSource " +
     "SELECT * FROM dbo.b.dtSource";
0
Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
LVL 28

Expert Comment

by:strickdd
ID: 17775373
This is quicker and cleaner because SQL can process it faster than ASP.Net code can loop through a DataTable.
0
 
LVL 7

Author Comment

by:brdrok
ID: 17775428
Thank you for this informational gold nugget...

I feel kind of silly asking this but I have a table with 40+ columns, is there anyway to just call the Update() without having to specify a gazillion parameters like the following?

// Create the InsertCommand.
   command = new SqlCommand(
        "INSERT INTO Customers (CustomerID, CompanyName) " +
        "VALUES (@CustomerID, @CompanyName)", connection);

    // Add the parameters for the InsertCommand.
    command.Parameters.Add("@CustomerID", SqlDbType.NChar, 5, "CustomerID");
    command.Parameters.Add("@CompanyName", SqlDbType.NVarChar, 40, "CompanyName");

thanks
0
 
LVL 7

Author Comment

by:brdrok
ID: 17775445
// Add the parameters for the InsertCommand.
    command.Parameters.Add("@CustomerID", SqlDbType.NChar, 5, dr["CustomerID"]);
    command.Parameters.Add("@CompanyName", SqlDbType.NVarChar, 40, dr["CompanyName"]);

etc
0
 
LVL 28

Assisted Solution

by:strickdd
strickdd earned 200 total points
ID: 17775603
If you are JUST inserting information the code I gave you will not require ANY parameters. If you JUST need to update then i believe this format will work:

UPDATE <table_name> <alias>
SET (<column_name>,<column_name> ) = (
   SELECT (<column_name>, <column_name>)
   FROM <table_name>
   WHERE <alias.column_name> = <alias.column_name>);


if you need to do both, you will need to find out which rows you are inserting and the run an insert on those rows after the update.
0
 
LVL 12

Expert Comment

by:topdog770
ID: 17775685
In Oracle, you would need to have a database link enabled to copy data from one database to another.
If you can copy from db to db directly in MS SQL then strickdd's approach is a good one


In this approach
===================
foreach(DataRow dr in dt.Rows)
{
    myDestinationDataTable.ImportRow(dr);
}
====================

1. Use an OleDataAdapter to fill the source table
2. Use an OleDataAdapter to set the schema in the destination table
3. Populate the destination table by using the import row approach
4. call the OleDataAdapter's Update for the destination table and you should be set.
You will not have to specifiy any parameters at all.



0
 
LVL 28

Expert Comment

by:strickdd
ID: 17775878
topdog770,
    If you read the initial question it is clearly stated that "Both databases are SQL Server 2005".
0
 
LVL 7

Author Comment

by:brdrok
ID: 17776695
Gentleman...thank you very much.  Learned quite a bit today.  

The only thing I had to add is the SetAdded() method

foreach(DataRow dr in dt.Rows)
{
    dr.SetAdded();
    myDestinationDataTable.ImportRow(dr);
}

otherwise my Update() wouldn't be able to find any records to insert.

0

Featured Post

Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

This article describes a simple method to resize a control at runtime.  It includes ready-to-use source code and a complete sample demonstration application.  We'll also talk about C# Extension Methods. Introduction In one of my applications…
Summary: Persistence is the capability of an application to store the state of objects and recover it when necessary. This article compares the two common types of serialization in aspects of data access, readability, and runtime cost. A ready-to…
This is my first video review of Microsoft Bookings, I will be doing a part two with a bit more information, but wanted to get this out to you folks.
Do you want to know how to make a graph with Microsoft Access? First, create a query with the data for the chart. Then make a blank form and add a chart control. This video also shows how to change what data is displayed on the graph as well as form…

696 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question