天天看點

C#安裝程式中打包MSDE的八個步驟

在Visual Studio 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的一個工具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:網絡通路的話也要加這項

重寫C#安裝程式Installer

下面方法适用于C#安裝程式,沒有添加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_r(Assembly. GetExecutingAssembly_r().Location)+"yourname.mdf";  

SqlParameter password=Cmd.Parameters.Add("@filename2",SqlDbType.NVarChar,50);  

password.value =Path. GetDirectoryName_r(Assembly. GetExecutingAssembly_r().Location)+"yourname.ldf";  

Connection.Open();  

Cmd.ExecuteNonQuery();  

Connection.Close();  

用附加資料庫,我認為是最好的解決辦法。

在沒有SQL環境的機器上運作你的C#安裝程式,會自動安裝MSDE,并附加你的資料庫,重起機器後,自動啟動Sql Server的執行個體。

本文轉自黃聰部落格園部落格,原文連結:http://www.cnblogs.com/huangcong/archive/2010/03/26/1697064.html,如需轉載請自行聯系原作者