DAC--使用DAC来导出数据库脚本
//==============================================
//功能介绍:使用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来导出数据库脚本的更多相关文章
- MySQL Workbench 导出数据库脚本(图文)
1.如下图红框所示,在Server Administration那里,点击"New Server Instance" 2.如下图所示,如果是连接本地数据库,则选localhost, ...
- PL SQLDEVELOPMENT导出数据库脚本
Tools--export Tables--选择表--SQL Inserts-- watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaHprMTU2MjExMD ...
- MySql数据库导出完整版(导出数据库,导出表,导出数据库结构)
MySql数据库导出完整版(导出数据库,导出表,导出数据库结构) 用MySqlCE导出数据库脚本时,如数据库中包含中文内容,则导出异常. 现在可以通过mysqldump.exe直接导出数据库脚本步骤如 ...
- SQL Server 2012 数据库数据导出为脚本
转自:http://blog.csdn.net/ituff/article/details/8265822 将高版本的的SQL Server数据库移到低版本的SQL Server是一件十分蛋疼的事,最 ...
- SQL Server2012如何导出sql脚本并且还原数据库
一 备份数据库 1 选择某一个数据库,右键依次选择:任务==>生成脚本: 2 选择要编写脚本的数据库对象,注意此处可以选择特定的数据库对象,我们可以选择我们需要备份的数据表. 3 在当 ...
- 使用PostgreSQL 脚本导出数据库的DDL
使用PostgreSQL 脚本导出数据库的DDL 本文主要介绍如何使用基于 PostgreSQL pgdump编写的自定义脚本来导出数据库的DDL. 一.文件说明: 1.pgdump基础语句.sql: ...
- MySQL导入sql脚本 导出数据库
导出数据库 不能停止服务 cd /var/lib/mysql (进入到MySQL库目录,根据自己的MySQL的安装情况调整目录) mysqldump -u用户名 -p 数据库名 > 导出的文件名 ...
- python实用脚本-定时导出数据库中的数据并且发送数据到邮箱
1.发送邮件脚本 #coding=utf-8 import smtplib from email.header import Header from email.mime.text import MI ...
- DB2导入导出数据库数据
导出数据库中数据 在db2cmd命令下生成建库脚本(-z指定模式名) db2look -d BBS -z db2admin -u db2admin -e -o bbs.sql 在db2cmd命令下导出 ...
随机推荐
- SQL dialect is not configured
在Idea中,xml配置文件报错:SQL dialect is not configured 解决方法如下: 在Idea中,在报错的地方按alt+enter,然后点击Generic配置dialect即 ...
- 人机大战中AlphaGo及其执子人黄士杰
2016年3月9日注定要写入围棋界的历史.IT界的历史以及科学界的历史.当天,韩国著名围棋棋手李世石VS谷歌AlphaGo的人机大战赛在韩国首尔举行.对弈的一方为拥有1200多个处理器的谷歌人工智能系 ...
- 【校招面试 之 C/C++】第13题 C++ 指针和引用的区别
1.指针和引用的定义和性质区别: (1)指针:指针是一个变量,只不过这个变量存储的是一个地址,指向内存的一个存储单元:而引用跟原来的变量实质上是同一个东西,只不过是原变量的一个别名而已.如: int ...
- Python Socket 编程详细介绍(转)
Python 提供了两个基本的 socket 模块: Socket 它提供了标准的BSD Socket API. SocketServer 它提供了服务器重心,可以简化网络服务器的开发. 下面讲解下 ...
- linux信号处理总结
本文主要讲解常见信号的处理方式. Sighup:终端关闭时,发送给此会话的所有进程组.Setsid成功后不再属于该会话,收不到该消息. Sigterm: kill process_id时产生. Si ...
- what's RNA-Seq?
- Git使用1
1.先配置本地Git E:\personal>git config –-global user.name "lewy" E:\personal>git config – ...
- JavaScript的replace方法与正则表达式结合应用讲解
大家好!!今晚在华软G43*宿舍没什么事做,把javascript中replace方法讲解一下,如果讲得不对或不合理是情理之中的事,因为我不是老鸟,也不是菜鸟,我也不知道我当底是什么鸟??呵~~ re ...
- 人类基因组三代组装: cano
git clone https://github.com/marbl/canu.git cd canu/src make -j <number of threads> 使用实例: canu ...
- 【Linux】Memcached安装
Memcached概念 Memcached是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载. MemCache的工作流程如下:先检查客户端的请求数据是否在memcached中, ...