C#打包数据库一起,按这个网(http://www.cnblogs.com/lijialong/archive/2010/07/09/SetupAppendDB.html)上的步骤一步步做的,绝对没错,都做了不下10次了。
可制作生成的安装包文件(附带数据库的程序),可为什么在双击安装文件时,安装到最后一步却出现了一个异常问题(状况如下图),有那个大侠能帮帮我呀!小弟万分感谢!出现的安装异常窗口;(图片连接:http://hi.baidu.com/chenxh515/album/item/8bb13d6555acbf62aa184c34.html)这是安装类的代码:
using System;
using System.Collections;
using System.Collections.Generic;
using System.ComponentModel;
using System.Configuration.Install;
using System.Linq;
using System.Data.SqlClient;
namespace InstallDB
{
[RunInstaller(true)]
public partial class InstallDB : Installer
{
public InstallDB()
{
InitializeComponent();
} /// <summary>
/// 附加数据库方法
/// </summary>
/// <param name="strSql">连接数据库字符串,连接master系统数据库</param>
/// <param name="DataName">数据库名字</param>
/// <param name="strMdf">数据库文件MDF的路径</param>
/// <param name="strLdf">数据库文件LDF的路径</param>
/// <param name="path">安装目录</param>
private void CreateDataBase(string strSql, string DataName, string strMdf, string strLdf, string path)
{
SqlConnection myConn = new SqlConnection(strSql);
String str = null;
try
{
str = " EXEC sp_attach_db @dbname='" + DataName + "',@filename1='" + strMdf + "',@filename2='" + strLdf + "'";
SqlCommand myCommand = new SqlCommand(str, myConn);
myConn.Open();
myCommand.ExecuteNonQuery();
//MessageBox.Show("数据库安装成功!点击确定继续");//需Using System.Windows.Forms
}
catch (Exception e)
{
//MessageBox.Show("数据库安装失败!" + e.Message + "\n\n" + "您可以手动附加数据");
System.Diagnostics.Process.Start(path);//打开安装目录
}
finally
{
myConn.Close();
}
}
public override void Install(System.Collections.IDictionary stateSaver)
{
string server = this.Context.Parameters["server"];//服务器名称
string uid = this.Context.Parameters["user"];//SQlServer用户名
string pwd = this.Context.Parameters["pwd"];//密码
string path = this.Context.Parameters["targetdir"];//安装目录
string strSql = "server=" + server + ";uid=" + uid + ";pwd=" + pwd + ";database=db_NewData";//连接数据库字符串 string DataName = "db_NewData";//数据库名
string strMdf = path + @"db_NewData.mdf";//MDF文件路径,这里需注意文件名要与刚添加的数据库文件名一样!
string strLdf = path + @"db_NewData_log.ldf";//LDF文件路径 base.Install(stateSaver);
this.CreateDataBase(strSql, DataName, strMdf, strLdf, path);//开始创建数据库
}
}
}
可制作生成的安装包文件(附带数据库的程序),可为什么在双击安装文件时,安装到最后一步却出现了一个异常问题(状况如下图),有那个大侠能帮帮我呀!小弟万分感谢!出现的安装异常窗口;(图片连接:http://hi.baidu.com/chenxh515/album/item/8bb13d6555acbf62aa184c34.html)这是安装类的代码:
using System;
using System.Collections;
using System.Collections.Generic;
using System.ComponentModel;
using System.Configuration.Install;
using System.Linq;
using System.Data.SqlClient;
namespace InstallDB
{
[RunInstaller(true)]
public partial class InstallDB : Installer
{
public InstallDB()
{
InitializeComponent();
} /// <summary>
/// 附加数据库方法
/// </summary>
/// <param name="strSql">连接数据库字符串,连接master系统数据库</param>
/// <param name="DataName">数据库名字</param>
/// <param name="strMdf">数据库文件MDF的路径</param>
/// <param name="strLdf">数据库文件LDF的路径</param>
/// <param name="path">安装目录</param>
private void CreateDataBase(string strSql, string DataName, string strMdf, string strLdf, string path)
{
SqlConnection myConn = new SqlConnection(strSql);
String str = null;
try
{
str = " EXEC sp_attach_db @dbname='" + DataName + "',@filename1='" + strMdf + "',@filename2='" + strLdf + "'";
SqlCommand myCommand = new SqlCommand(str, myConn);
myConn.Open();
myCommand.ExecuteNonQuery();
//MessageBox.Show("数据库安装成功!点击确定继续");//需Using System.Windows.Forms
}
catch (Exception e)
{
//MessageBox.Show("数据库安装失败!" + e.Message + "\n\n" + "您可以手动附加数据");
System.Diagnostics.Process.Start(path);//打开安装目录
}
finally
{
myConn.Close();
}
}
public override void Install(System.Collections.IDictionary stateSaver)
{
string server = this.Context.Parameters["server"];//服务器名称
string uid = this.Context.Parameters["user"];//SQlServer用户名
string pwd = this.Context.Parameters["pwd"];//密码
string path = this.Context.Parameters["targetdir"];//安装目录
string strSql = "server=" + server + ";uid=" + uid + ";pwd=" + pwd + ";database=db_NewData";//连接数据库字符串 string DataName = "db_NewData";//数据库名
string strMdf = path + @"db_NewData.mdf";//MDF文件路径,这里需注意文件名要与刚添加的数据库文件名一样!
string strLdf = path + @"db_NewData_log.ldf";//LDF文件路径 base.Install(stateSaver);
this.CreateDataBase(strSql, DataName, strMdf, strLdf, path);//开始创建数据库
}
}
}
解决方案 »
- C# 如何获取迅雷弹出提示窗口的句柄,并触发“立即下载”按钮的Click事件
- 求助,高手进
- 怎样将这样一个字符串里放的多个表明转变成内连接字符串
- HashTable和多线程
- c# 遍历控件的顺序问题!!
- 求.NET序号算法
- 关于将ORACLE9.0中数据导入到ORACLE8.0中---在线急等!!!!
- ¥¥¥¥百分查错¥¥¥¥高手帮忙
- 不知道会不会被删帖,,,问一句:这里有人用C#开发共享软件吗?
- 怎么写一个通用方法来 调用存储过程
- 关于C#Winform的listbox的一个问题
- 2010 WPF里面的DataGrid怎么放一个CheckBox 怎么绑值,点击一个按钮后怎么获得每一行CheckBox 的选中状态和对应的ID..
添加主输出和内容文件
System.Diagnostics.Debugger.Launch();
代码调试