How do you copy a MS SQL 2000 database programmatically using C#?

时光毁灭记忆、已成空白 提交于 2019-12-23 19:28:48

问题


I need to copy several tables from one DB to another in SQL Server 2000, using C# (VS 2005). The call needs to be parameterized - I need to be able to pass in the name of the database to which I am going to be copying these tables.

I could use DTS with parameters, but I can't find any sample code that does this from C#.

Alternatively, I could just use

drop table TableName
select * into TableName from SourceDB..TableName

and then reconstruct the indexes etc - but that is really kludgy.

Any other ideas?

Thanks!


回答1:


For SQL Server 7.0 and 2000, we have SQLDMO for this. For SQL Server 2005 there is SMO. This allows you do to pretty much everything related to administering the database, scripting objects, enumerating databases, and much more. This is better, IMO, than trying a "roll your own" approach.

SQL 2000: Developing SQL-DMO Applications

Transfer Object

SQL 2005: Here is the SMO main page: Microsoft SQL Server Management Objects (SMO)

Here is the Transfer functionality: Transferring Data

How to: Transfer Schema and Data from One Database to Another in Visual Basic .NET




回答2:


If the destination table is being dropped every time then why not do SELECT INTO? Doesn't seem like a kludge at all.

If it works just fine and ticks all the requirements boxes why create a days worth of work growing code to do exactly the same thing?

Let SQL do all the heavy lifting for you.




回答3:


You could put the scripts (copy db) found here

http://www.codeproject.com/KB/database/CreateDatabaseScript.aspx

Into an application. Just replace the destination. To actually move the entite database, FOLLOW

http://support.microsoft.com/kb/314546

But remember, the database has to be taken offline first.

Thanks



来源:https://stackoverflow.com/questions/174515/how-do-you-copy-a-ms-sql-2000-database-programmatically-using-c

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!