VS Web项目安装部署(安装数据库[执行sql脚本]并将连接写入web.config)
一、如果网站安装不需安装数据库。
1.打开已有网站->发布网站->确定。
2.在解决方案中添加->新建项目->其它项目类型->安装和布署->WEB安装项目-确定。
3.通过添加文件把发布的网站中的文件添加到出来的文件系统->WEB应用程序文件夹。也可以把文件直接拖到里面,效果一样。
4.生成WEB安装项目。简单打包就完成了。
二、部署带数据库(sql server)的web应用程序
1.打开已有网站->发布网站->确定(得到要发布的内容)。
2.在解决方案中添加->新建项目->其它项目类型->安装和布署->WEB安装项目-确定。
3.将要发布的内容添加到安装项目中(包括table.sql文件)。
4.选中web安装项目->用户界面编辑器,在启动下:添加对话框->文本框(A)->右键属性,
Edit1Label 属性并键入:数据库名称:。
Edit1Property 属性并键入 CUSTOMTEXTA1。
Edit1Value 属性并键入:customdb。
Edit2Label 属性并键入:服务器名:。
Edit2Property 属性并键入 CUSTOMTEXTA2。
Edit2Value 属性并键入:localhost
Edit3Label 属性并键入:用户名:。
Edit3Value 属性并键入:sa。
Edit3Property 属性并键入 CUSTOMTEXTA3。
Edit4Label 属性并键入:密码:。
Edit4Property 属性并键入 CUSTOMTEXTA4。
移动到适当位置。
5.在当前解决方案中添加新建类库项目(DBInstaller),在项目中添加安装程序类(类中代码在下)。
6.添加web安装项目输出,选择DBInstaller。
7.选中web安装项目->自定义操作编辑器-安装-添加自定义操作,找到6中添加的文件,
设置所添加文件的属性CustomActionData:/dbname=[EDITA1] /server=[EDITA2] /user=[EDITA3] /pwd=[EDITA4] /targetdir="[TARGETDIR]/"
8.生成。
类中方法代码:
Code
public override void Install(IDictionary stateSaver)
{
base.Install(stateSaver);
string connStr = string.Format("data source={0};user id={1};password={2};persist security info=false;packet size=4096", this.Context.Parameters["server"], this.Context.Parameters["user"], this.Context.Parameters["pwd"]);
ExecuteSql(connStr, "master", "CREATE DATABASE " + this.Context.Parameters["dbname"]);
StringBuilder sb = this.GetSqlFile("table.sql");
ExecuteSql(connStr, this.Context.Parameters["dbname"], sb.ToString());
}
// 获取Sql文件里的脚本
private StringBuilder GetSqlFile(string pFileName) {
StringBuilder sqlTemp = new StringBuilder();
sqlTemp.Append(File.ReadAllText(this.Context.Parameters["targetdir"] + "//"+ pFileName, System.Text.Encoding.GetEncoding("GB2312")));
return sqlTemp;
}
private void ExecuteSql(string connStr, string DatabaseName, string Sql)
{
using (SqlConnection conn = new SqlConnection(connStr))
{
SqlCommand cmd = new SqlCommand(Sql, conn);
conn.Open();
conn.ChangeDatabase(DatabaseName);
try
{
cmd.ExecuteNonQuery();
}
finally
{
conn.Close();
}
}
}