//==============================================

//功能介绍:使用DAC来导出数据库脚本

//注意事项:

//1.本程序涉及到的DLL有:

//  --Microsoft.SqlServer.ConnectionInfo.dll

//  --Microsoft.SqlServer.Management.Dac.dll

//  --Microsoft.SqlServer.Management.Sdk.Sfc.dll

// --Microsoft.SqlServer.Management.SmoMetadataProvider.dll

//2.以上DLL可以在C:\Windows\assembly\GAC_MSIL下找到,

//如果找不到,可以使用SQLSERVER 2012安装包安装以下MSI:

//  --SQLSysClrTypes.msi

//  --SharedManagementObjects.msi

//  --DACFramework.msi

//

//==============================================

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Data.SqlClient;

using Microsoft.SqlServer.Management.Common;

using Microsoft.SqlServer.Management.Dac;

using Microsoft.SqlServer.Management.Smo;

using System.IO;

class DACExtracter

{

private List <string>GetDatabaseNames(SqlConnection conn)

{

SqlCommand comm = newSqlCommand( "SELECT name FROM sys.databases where database_id>4",conn);

List<string >dbNames = new List<string >();

try

{

conn.Open();

SqlDataReader reader= comm.ExecuteReader();

while(reader.Read())

{

dbNames.Add(reader["name" ].ToString());

}

return dbNames;

}

catch

{

Console.WriteLine("connect dbfailed");

throw(new Exception("connect db failed"));

}

finally

{

if(conn!=null )

{

conn.Close();

conn.Dispose();

}

}

}

public voidExtractDAC(string connectionString, string extractFolderPath)

{

try

{

SqlConnectionsqlConnection = new SqlConnection(connectionString);

ServerConnectionconn = new ServerConnection(sqlConnection);

Server destServer =new Server(conn);

List<string >dbNames = GetDatabaseNames(sqlConnection);

string version ="1.0.0.1" ;

foreach (stringdbName in dbNames)

{

ExtractDAC(destServer, dbName, version, extractFolderPath);

}

}

catch(Exception )

{

Console.WriteLine("End with error" );

}

}

private voidExtractDAC(Server destServer,string databaseName,string version,stringextractFolderPath)

{

try

{

Console.WriteLine(destServer.Information.Version);

DacExtractionUnitdacUnit = new DacExtractionUnit(destServer, databaseName, databaseName, newVersion (version));

DirectoryInfo dir =new DirectoryInfo(extractFolderPath);

if (!dir.Exists)

{

dir.Create();

}

string dacFilePath =dir.FullName + @"\" + databaseName + ".dacpac" ;

if (!File.Exists(dacFilePath))

{

File.Delete(dacFilePath);

}

dacUnit.Extract(dacFilePath);

Console.WriteLine("extract "+databaseName+"successfully");

}

catch(IOException )

{

Console.WriteLine("please check extract folder");

Console.WriteLine("extract " + databaseName + "failed" );

}

catch (Exception )

{

Console.WriteLine("extract " + databaseName + "failed" );

}

}

}

static void Main(string[] args)

{

String connectionString= "Data Source=88.88.88.88,18991;Initial Catalog=master;IntegratedSecurity=False;User ID=sa;Password=sa;";

DACExtracterdacExtracter = new DACExtracter();

dacExtracter.ExtractDAC(connectionString, @"E:\DBScript" );

Console.WriteLine("press any key to close");

Console.ReadLine();

}

DAC--使用DAC来导出数据库脚本的更多相关文章

  1. MySQL Workbench 导出数据库脚本(图文)

    1.如下图红框所示,在Server Administration那里,点击"New Server Instance" 2.如下图所示,如果是连接本地数据库,则选localhost, ...

  2. PL SQLDEVELOPMENT导出数据库脚本

    Tools--export Tables--选择表--SQL Inserts-- watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaHprMTU2MjExMD ...

  3. MySql数据库导出完整版(导出数据库,导出表,导出数据库结构)

    MySql数据库导出完整版(导出数据库,导出表,导出数据库结构) 用MySqlCE导出数据库脚本时,如数据库中包含中文内容,则导出异常. 现在可以通过mysqldump.exe直接导出数据库脚本步骤如 ...

  4. SQL Server 2012 数据库数据导出为脚本

    转自:http://blog.csdn.net/ituff/article/details/8265822 将高版本的的SQL Server数据库移到低版本的SQL Server是一件十分蛋疼的事,最 ...

  5. SQL Server2012如何导出sql脚本并且还原数据库

    一  备份数据库 1  选择某一个数据库,右键依次选择:任务==>生成脚本: 2  选择要编写脚本的数据库对象,注意此处可以选择特定的数据库对象,我们可以选择我们需要备份的数据表. 3   在当 ...

  6. 使用PostgreSQL 脚本导出数据库的DDL

    使用PostgreSQL 脚本导出数据库的DDL 本文主要介绍如何使用基于 PostgreSQL pgdump编写的自定义脚本来导出数据库的DDL. 一.文件说明: 1.pgdump基础语句.sql: ...

  7. MySQL导入sql脚本 导出数据库

    导出数据库 不能停止服务 cd /var/lib/mysql (进入到MySQL库目录,根据自己的MySQL的安装情况调整目录) mysqldump -u用户名 -p 数据库名 > 导出的文件名 ...

  8. python实用脚本-定时导出数据库中的数据并且发送数据到邮箱

    1.发送邮件脚本 #coding=utf-8 import smtplib from email.header import Header from email.mime.text import MI ...

  9. DB2导入导出数据库数据

    导出数据库中数据 在db2cmd命令下生成建库脚本(-z指定模式名) db2look -d BBS -z db2admin -u db2admin -e -o bbs.sql 在db2cmd命令下导出 ...

随机推荐

  1. Loadrunner通过吞吐量计算每个用户需要的带宽

    Loadrunner通过吞吐量计算每个用户需要的带宽 运行一个场景,点击Analysis进行分析,使用分析报告中的Average Throughput(bytes/second)进行计算. 计算公式: ...

  2. 转)安装svn服务器

    以下转载自:http://www.linuxidc.com/Linux/2015-01/111956.htm 安装 安装软件包: sudo apt-get install subversion 配置 ...

  3. jsp清除缓存

    好多代码都是: <% response.setHeader("Cache-Control", "no-store"); //HTTP 1.1 respon ...

  4. 解读超轻量级DI容器-Guice与Spring框架的区别【转载】

    依赖注入,DI(Dependency Injection),它的作用自然不必多说,提及DI容器,例如spring,picoContainer,EJB容器等等,近日,google诞生了更轻巧的DI容器… ...

  5. 5-分西瓜差最小(背包 || dfs)

    /*   zb立刻下定决心买了一堆西瓜.当他准备把西瓜送给C小加和never的时候,遇到了一个难题,never和C小加不在一块住,只能把西瓜分成两堆给他们,为了对每个人都公平,他想让两堆的重量之差最小 ...

  6. Mysql、Oracle、SqlServer的JDBC连接实现和对比(提供驱动包)

    首先,我们需要准备数据库连接所需的jar包.目前mysql的驱动包可能比较好找,但是oracle和sqlserver的有很多,要找到能用的要花一点点心思,这里直接把下载地址和版本发送出来. Mysql ...

  7. Mina入门:mina版之HelloWorld[z]

    Mina入门:mina版之HelloWorld [z] 一,前言: 在完成上篇文章<Mina入门:Java NIO框架Mina.Netty.Grizzly简介与对比>之后,我们现在可以正式 ...

  8. JavaScript开发者的工具箱

    自从HTML5变得流行以来,整个Web平台取得了长足的进步,人们也开始将JavaScript视为一门能够创建复杂应用的语言.许多新的API纷纷浮现,而关于浏览器如何应用这些技术的文章也大量涌现. 作为 ...

  9. [Selenium]当DOM结构里面有iFrame,iFrame里面是html,怎么send keys to 里面的body,怎么用Assert进行验证?

    我在测试的过程中遇到一个这样的问题,我无法通过CssSelector找到iFrame下边的html: <div id="mailEditorDiv" style=" ...

  10. 类方法 isAssignableFrom、instanceof 和 asSubclass

    类方法 isAssignableFrom.instanceof 和 asSubclass Spring 框架 CollectionFactory 的 asEnumType 方法使用 "类.a ...