C#.net应用程序打包时怎样把Sql数据库一同打包? 我在网上找到了3中打包方法,有一种是必须是客户机必须有sql server程序的!有没有不用在客户机上安装sql server 的! 谢谢! 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 msdb怎么装?我是初学者,请多指教! msdb怎么装?我是初学者,请多指教! 能不能给我说说具体步骤!谢谢! 这是我引用别人的来进行回答,我就是用这样的方法在程序启动的时候附加数据库的.......在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->1799 1500-1499RemoveExistingProducts 1825->1800 1525-1500InstallUISequence表GetSqlStates.XXXXXX 103->421Property表添加SqlInstanceName: :您的实例名称SqlSecurityMode: SQLSqlSaPwd: :您的实例密码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的实例/dbName=[DBNAME] /user=[USER] /pwd=[PWD]\ MSDE2000的sp3a安装包 在什么地方下载?我找不到! 把您的邮箱给我吧,我发给你...是二十几个MSM模块 我的郵箱是:[email protected]謝謝您的執教!萬分感謝! 我的郵箱是:[email protected]謝謝 xiejun20 謝謝您的執教!萬分感謝! 没有听过说是把SQL数据库一起打包进去的! xiejun20 请问您用这个方法试成功了吗? 利用这个方法可以...只是我把下面的代码部分放在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; } 您这个方法是不是需要在安装有SQL 2000的客户机上才能行呀? C#求高手 C# WinForm 未将对象引用到实例 C#中链接数据库的问题。急求。谢谢 SOS添加远程flash地址无法显示,但是添加同一个数据夹下面的可以显示 如何操作我的程序的另一个实例(进程)? 请问如何用C#实现定时在主程序中运行一个进程?? 如何定义一个指向TreeView 根节点的指针? c#实现获取视频中某一帧的图像 水晶报表通过点击按钮,控制图片是否显示 急!!!一个bool型的函数为什么出错? 数据集中如何获得存储过程中的返回值? ctype(变量,类型)发生了什么事情
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]\
是二十几个MSM模块
謝謝您的執教!
萬分感謝!
謝謝 xiejun20
謝謝您的執教!
萬分感謝!
xiejun20 请问您用这个方法试成功了吗?
只是我把下面的代码部分放在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;
}