我在网上找到了3中打包方法,有一种是必须是客户机必须有sql server程序的!
有没有不用在客户机上安装sql server 的!
  谢谢!

解决方案 »

  1.   

    msdb怎么装?我是初学者,请多指教!
      

  2.   

    msdb怎么装?我是初学者,请多指教! 能不能给我说说具体步骤!谢谢!
      

  3.   

    这是我引用别人的来进行回答,我就是用这样的方法在程序启动的时候附加数据库的.......在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的一个工具ORCA
    8.用ORCA打开安装包文件MySetup.msi
    InstallExecuteSequence表
    GetSqlStates.XXXXXX        103->421
    InstallInitialize          1800->1799    1500-1499
    RemoveExistingProducts     1825->1800  1525-1500
    InstallUISequence表
    GetSqlStates.XXXXXX        103->421
    Property表添加
    SqlInstanceName:          :您的实例名称
    SqlSecurityMode:          SQL
    SqlSaPwd:                 :您的实例密码
    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的实例
    /dbName=[DBNAME] /user=[USER] /pwd=[PWD]\
      

  4.   

    MSDE2000的sp3a安装包 在什么地方下载?我找不到!
      

  5.   

    把您的邮箱给我吧,我发给你...
    是二十几个MSM模块
      

  6.   

    我的郵箱是:[email protected]
    謝謝您的執教!
    萬分感謝!
      

  7.   

    我的郵箱是:[email protected]
    謝謝 xiejun20 
    謝謝您的執教!
    萬分感謝!
      

  8.   

    没有听过说是把SQL数据库一起打包进去的!
      

  9.   


    xiejun20  请问您用这个方法试成功了吗?
      

  10.   

    利用这个方法可以...
    只是我把下面的代码部分放在Program部分,具体的你可以见我的代码:
    try
                {
                    ServiceController service = new ServiceController("MSSQL$EXAMPLE");--您的实例名
                    if (service.Status == ServiceControllerStatus.Stopped)
                    {
                        service.Start();
                    }
                    string connStr = "password=111;user id=sa;data source=" + SystemInformation.ComputerName + "\\EXAMPLE";
                    SqlConnection conn = new SqlConnection(connStr);
                    conn.Open();
                    conn.ChangeDatabase("master");
                    string sql = "SELECT name FROM master.dbo.sysdatabases WHERE name = N'example'";---您EXAMPLE实例下的example数据库,即您所需要附加的数据库
                    SqlCommand com = new SqlCommand(sql, conn);
                    string m = (string)com.ExecuteScalar();
                    if (m != "example")
                  {
                    SqlCommand Cmd = new SqlCommand("sp_attach_db", conn);
                    Cmd.CommandType = CommandType.StoredProcedure;
                    SqlParameter dbName = Cmd.Parameters.Add("@dbname", SqlDbType.NVarChar, 20);
                    dbName.Value = "example";
                    SqlParameter mdfPath = Cmd.Parameters.Add("@filename1", SqlDbType.NVarChar, 255);
                    mdfPath.Value = "C:\\Program Files\\WanFang\\DataInsight\\example.mdf";
                    SqlParameter ldfPath = Cmd.Parameters.Add("@filename2", SqlDbType.NVarChar, 255);
                    ldfPath.Value = "C:\\Program Files\\WanFang\\DataInsight\\example_log.ldf";
                    Cmd.ExecuteNonQuery();
                }
                    conn.Close();
                }
                catch (Exception e)
                {
                    MessageBox.Show("数据库初始化和恢复失败,整个安装失败!");
                    MessageBox.Show(e.ToString());
                    Application.Exit();
                    return;
                }
      

  11.   

    您这个方法是不是需要在安装有SQL 2000的客户机上才能行呀?