• 黄聪: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

     

    1. public override void Commit(IDictionary savedState)  
    2. {  
    3. base.Commit (savedState);  
    4. //启动windows服务  
    5. new System.ServiceProcess.ServiceController("MSSQLSERVER").Start();  
    6. //附加数据库  
    7. SqlConnection Connection new SqlConnection("password=**;user id=sa;data source="+SystemInformation.ComputerName);  
    8. SqlCommand Cmd new SqlCommand("sp_attach_db",Connection);  
    9. Cmd.CommandType CommandType.StoredProcedure;  
    10. SqlParameter loginname=Cmd.Parameters.Add("@dbname",SqlDbType.NVarChar,20);  
    11. loginname.value ="yourname";  
    12. SqlParameter nickname=Cmd.Parameters.Add("@filename1",SqlDbType.NVarChar,50);  
    13. nickname.value =Path. GetDirectoryName_r(Assembly. GetExecutingAssembly_r().Location)+"yourname.mdf";  
    14. SqlParameter password=Cmd.Parameters.Add("@filename2",SqlDbType.NVarChar,50);  
    15. password.value =Path. GetDirectoryName_r(Assembly. GetExecutingAssembly_r().Location)+"yourname.ldf";  
    16. Connection.Open();  
    17. Cmd.ExecuteNonQuery();  
    18. Connection.Close();  

     

    用附加数据库,我认为是最好的解决办法。

    在没有SQL环境的机器上运行你的C#安装程序,会自动安装MSDE,并附加你的数据库,重起机器后,自动启动Sql Server的实例。

  • 相关阅读:
    Ruby窗口程序
    RubyWin32Api Win32OLE
    Ruby网络服务
    Ruby 文件处理
    Ruby基础数据类型
    Ruby基础类型,动态特性,代码块
    Ruby类,模块1
    Ruby准备工作
    js变量作用域
    ExecuteStoreQuery
  • 原文地址:https://www.cnblogs.com/huangcong/p/1697064.html
Copyright © 2020-2023  润新知