The following works on my machine (Win 7.0, .NET 4.0, VS 2010) I created a simple application for Win forms with the OK button and called the function below.
Note. I first added if (myTable.IsSystemObject == true) continues; To ensure that system views are not scripted I have not tested if this is really necessary:
public static string ScriptDatabase( string dbConnectionString, string databaseName ) { SqlConnection conn = new SqlConnection( dbConnectionString ); ServerConnection serverConn = new ServerConnection( conn ); var server = new Server( serverConn ); var database = server.Databases[ databaseName ]; var scripter = new Scripter( server ); scripter.Options.IncludeIfNotExists = true; scripter.Options.ScriptSchema = true; scripter.Options.ScriptData = true; string scrs = ""; string tbScr = "";
Output:
SET ANSI_NULLS ON SET QUOTED_IDENTIFIER ON IF NOT EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[tBlah]') AND type in (N'U')) BEGIN CREATE TABLE [dbo].[tBlah]( [ID] [int] IDENTITY(1,1) NOT NULL, [tID] [varchar](20) COLLATE Latin1_General_CI_AS NULL, [Value] [varchar](20) COLLATE Latin1_General_CI_AS NULL ) ON [PRIMARY] END SET IDENTITY_INSERT [dbo].[tBlah] ON INSERT [dbo].[tBlah] ([ID], [tID], [Value]) VALUES (1, N'2', N'1234') INSERT [dbo].[tBlah] ([ID], [tID], [Value]) VALUES (2, N'2', N'345.6')
MSDN Links:
Alex
source share