C# 打包 msde数据库 如何把msde数据库 打进去 并创建一个实例然后启动服务 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 参考在VS 2003的工程中添加Microsoft SQL Server 2000 Desktop Engine (MSDE)的自动安装合并模块MSM:1.下载MSDE2000的sp3a安装包。2.解压到本地硬盘,其中的MSM文件夹中的东东就是MSDE2000合并模块。3.在你的工程中添加一个安装工程假设为MySetup,按照正常的步骤添加工程输出(Project Output),选择输出文件(primary output)和内容文件(content files)两项。4.添加合并模块(Merge Moudle),选择浏览,指定到你的MSDE的MSM文件夹,选择MSM(不包括msm1033和msm2052)下的所有的文件(REPL.MSM、 REPL_RES.MSM、 DMO_RES.MSM和DMO.MSM可以不选),打开。5.设置安装工程的属性(Properties)中的SearchPath,指定为你的MSM所在路径(MSM和MSM1033和MSM2052)。6.设置好安装程序的其他属性,这时就可以对你的安装工程进行编译了。7.我们需要修改打好的安装包,使它可以在安装完程序后自动安装MSDE的一个实例(假设实例名为:MyServer)。我们需要用到MS的一个工具ORCA8.用ORCA打开安装包文件MySetup.msiInstallExecuteSequence表GetSqlStates.XXXXXX 103->421InstallInitialize 1800->1799RemoveExistingProducts 1825->1800InstallUISequence表GetSqlStates.XXXXXX 103->421Property表添加SqlInstanceName: MSDEDH实例服务名SqlSecurityMode: SQL 用SQL模式登录SqlSaPwd: sa的密码DISABLENETWORKPROTOCOLS=0:网络访问的话也要加这项重写Installer下面方法适用于,没有添加SqlInstanceName:这个属性,用机器名访问msdepublic override void Commit(IDictionary savedState){base.Commit (savedState);//启动windows服务new System.ServiceProcess.ServiceController("MSSQLSERVER").Start();//附加数据库SqlConnection Connection = new SqlConnection("password=**;user id=sa;data source="+SystemInformation.ComputerName);SqlCommand Cmd = new SqlCommand("sp_attach_db",Connection);Cmd.CommandType = CommandType.StoredProcedure;SqlParameter loginname=Cmd.Parameters.Add("@dbname",SqlDbType.NVarChar,20);loginname.Value ="yourname";SqlParameter nickname=Cmd.Parameters.Add("@filename1",SqlDbType.NVarChar,50);nickname.Value =Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location)+"yourname.mdf";SqlParameter password=Cmd.Parameters.Add("@filename2",SqlDbType.NVarChar,50);password.Value =Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location)+"yourname.ldf";Connection.Open();Cmd.ExecuteNonQuery();Connection.Close();}用附加数据库,我认为是最好的解决办法。在没有SQL环境的机器上运行你的安装包,会自动安装MSDE,并附加你的数据库,重起机器后,自动启动Sql Server的实例。 软件升级的问题?希望高手可以帮我解答.先谢过 求助 Hook钩子的问题,求前辈指点!急~ 求一算法,计算流程中最长时间 C# 求个模式? 问一下如何操作excel文档,我想在里面画线,绘制曲线图 急求 ,打开一个新页面,但不关闭原页面 VS2012WEB项目如何附加到进程进行本机调试 请问在.net里面如何调用Oracle的语句块?难道.net对待Oracle真这么烂。 简单问题 (100分)遍历xml修改属性 winform定时备份数据库
1.下载MSDE2000的sp3a安装包。
2.解压到本地硬盘,其中的MSM文件夹中的东东就是MSDE2000合并模块。
3.在你的工程中添加一个安装工程假设为MySetup,按照正常的步骤添加工程输出(Project Output),选择输出文件(primary output)和内容文件(content files)两项。
4.添加合并模块(Merge Moudle),选择浏览,指定到你的MSDE的MSM文件夹,选择MSM(不包括msm1033和msm2052)下的所有的文件(REPL.MSM、 REPL_RES.MSM、 DMO_RES.MSM和DMO.MSM可以不选),打开。
5.设置安装工程的属性(Properties)中的SearchPath,指定为你的MSM所在路径(MSM和MSM1033和MSM2052)。
6.设置好安装程序的其他属性,这时就可以对你的安装工程进行编译了。
7.我们需要修改打好的安装包,使它可以在安装完程序后自动安装MSDE的一个实例(假设实例名为:MyServer)。我们需要用到MS的一个工具ORCA
8.用ORCA打开安装包文件MySetup.msi
InstallExecuteSequence表
GetSqlStates.XXXXXX 103->421
InstallInitialize 1800->1799
RemoveExistingProducts 1825->1800
InstallUISequence表
GetSqlStates.XXXXXX 103->421
Property表添加SqlInstanceName: MSDEDH实例服务名
SqlSecurityMode: SQL 用SQL模式登录
SqlSaPwd: sa的密码
DISABLENETWORKPROTOCOLS=0:网络访问的话也要加这项重写Installer
下面方法适用于,没有添加SqlInstanceName:这个属性,用机器名访问msde
public override void Commit(IDictionary savedState)
{
base.Commit (savedState);
//启动windows服务
new System.ServiceProcess.ServiceController("MSSQLSERVER").Start();
//附加数据库
SqlConnection Connection = new SqlConnection("password=**;user id=sa;data source="+SystemInformation.ComputerName);
SqlCommand Cmd = new SqlCommand("sp_attach_db",Connection);
Cmd.CommandType = CommandType.StoredProcedure;
SqlParameter loginname=Cmd.Parameters.Add("@dbname",SqlDbType.NVarChar,20);
loginname.Value ="yourname";
SqlParameter nickname=Cmd.Parameters.Add("@filename1",SqlDbType.NVarChar,50);
nickname.Value =Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location)+"yourname.mdf";
SqlParameter password=Cmd.Parameters.Add("@filename2",SqlDbType.NVarChar,50);
password.Value =Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location)+"yourname.ldf";
Connection.Open();
Cmd.ExecuteNonQuery();
Connection.Close();
}
用附加数据库,我认为是最好的解决办法。
在没有SQL环境的机器上运行你的安装包,会自动安装MSDE,并附加你的数据库,重起机器后,自动启动Sql Server的实例。