ASP.NET安装和部署中数据库的问题

lanye_purple 2006-11-08 09:39:33
现我在ASP.NET部署数据库时出现这样一个问题..如果sql.txt中遇到有存储过程,安装程序将会出错误..提示错误:ExecuteNonQuery:CommandText 属性尚未初始化 然后数据确实在SQL中存在了..但里面没有内容,表一个都没有. 觉得代码需要改进,麻烦高手指点了(这段代码是网上找的,很多地方都有)

代码如下:

using System;
using System.Collections;
using System.ComponentModel;
using System.Configuration.Install;
using System.IO;
using System.Data.SqlClient;
using System.Reflection;

namespace DBCustomAction
{
/// <summary>
/// DBCustomAction 的摘要说明。
/// </summary>
[RunInstaller(true)]
public class DBCustomAction : System.Configuration.Install.Installer
{
/// <summary>
/// 必需的设计器变量。
/// </summary>
private System.ComponentModel.Container components = null;
private string strPass = "";
private string strUser = "";
private string strServer = "";

public DBCustomAction()
{
// 该调用是设计器所必需的。
InitializeComponent();

// TODO: 在 InitializeComponent 调用后添加任何初始化
}

/// <summary>
/// 清理所有正在使用的资源。
/// </summary>
protected override void Dispose( bool disposing )
{
if( disposing )
{
if(components != null)
{
components.Dispose();
}
}
base.Dispose( disposing );
}

#region 组件设计器生成的代码
/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
components = new System.ComponentModel.Container();
}


public override void Install(System.Collections.IDictionary stateSaver)
{
//入口
strPass = this.Context.Parameters["strPass"];
strUser = this.Context.Parameters["strUser"];
strServer = this.Context.Parameters["strServer"];
AddDBTable("RequestSys");//RequestSys为数据库名称
}
protected void AddDBTable(string strDBName )
{
try
{
//Create the database.
ExecuteSql("master", "CREATE DATABASE " + strDBName);
// Create the tables.
ExecuteSql(strDBName, GetSql("sql.txt"));
}
catch(Exception ex)
{
throw ex;
}
}

private void ExecuteSql(string DatabaseName , string Sql)
{
SqlConnection conn = new SqlConnection("user id="+strUser+";password="+strPass+";database=master;server="+strServer) ;
SqlCommand Command = new SqlCommand(Sql,conn);
Command.Connection.Open();
Command.Connection.ChangeDatabase(DatabaseName);

try
{
Command.ExecuteNonQuery();
}
catch(Exception ex)
{
throw ex ;
}
finally
{
// Finally, blocks are a great way to ensure that the connection
Command.Connection.Close();
}
}
private string GetSql(string strName)
{
try
{
//' Get the current assembly.
Assembly Asm = Assembly.GetExecutingAssembly();
// Resources are named using a fully qualified name
Stream strm = Asm.GetManifestResourceStream(Asm.GetName().Name + "." + strName);
//Read the contents of the embedded file.
StreamReader reader= new StreamReader(strm);//,System.Text.Encoding.Unicode);
return reader.ReadToEnd();
}
catch
{
return null;
}

}
...全文
386 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
Lenson_Z 2006-11-17
  • 打赏
  • 举报
回复
我也遇到类似的问题!
我的情况是:单独放建立表的SQL语句到SQL.txt可以通过,可以建立表。但是把建立视图(建立相关的表放在建立该视图之前,而且建立视图的SQL语句是正确的),但是出错,结果知识建立数据库,表和视图都无法建立。
解决办法:把建立表的SQL语句单独放在sql.txt;建立视图的SQL语句放在sqlv.txt;先执行sql.txt,再执行sqlv.txt,成功!!
我想你出现这种情况的问题应该是跟我这种情况是一样的,所以可以借鉴该方法。
lanye_purple 2006-11-08
  • 打赏
  • 举报
回复
我现在也是想用这种方式..
那具体应该怎么做..
hymxtang 2006-11-08
  • 打赏
  • 举报
回复
ASP.NET项目安装部署时,我都是先把数据库备份了,再一起打包觉得比较方便
lanye_purple 2006-11-08
  • 打赏
  • 举报
回复
是我没有说清楚,还是怎么地啊...
lanye_purple 2006-11-08
  • 打赏
  • 举报
回复
感谢帮顶..

怎么还是没有人来弄一下啊..
gezichong 2006-11-08
  • 打赏
  • 举报
回复
我帮你顶一下看看
lanye_purple 2006-11-08
  • 打赏
  • 举报
回复
没有人知道吗..

只有这么多分了..感兴趣的也帮忙顶一下啊.
lanye_purple 2006-11-08
  • 打赏
  • 举报
回复
trytoday 发表于2006-07-28 23:33:00 IP: 221.216.166.*
我用的是一种更简单的方法,不论数据库里有什么都无所谓。就是把数据库的备份(或.mdf文件)打包,建立数据库的时候还原(或连接上)就可以了。这样也方便指定数据库新路径。

刚在网上收了一下..上面的方法是我想要的.把数据库的备份或.mdf文件)打包,但这位朋友没有把代码贴出来..有知道的麻烦帮一下..
现在很急...

lanye_purple 2006-11-08
  • 打赏
  • 举报
回复
唉..世道太公了.
发了一天的贴了..都没有人怎么理啊..
ASP.NET ASP.NET 概述 ASP.NET 是一个统一的 Web 开发模型,它包括您使用尽可能少的代码生成企业级 Web 应用程序所必需的各种服务。ASP.NET 作为 .NET Framework 的一部分提供。当您编写 ASP.NET 应用程序的代码时,可以访问 .NET Framework 的类。您可以使用与公共语言运行库 (CLR) 兼容的任何语言来编写应用程序的代码,这些语言包括 Microsoft Visual Basic、C#、JScript .NET 和 J#。使用这些语言,可以开发利用公共语言运行库、类型安全、继承等方面的优点的 ASP.NET 应用程序。 ASP.NET 包括: 页和控件框架 ASP.NET 编译器 安全基础结构 状态管理功能 应用程序配置 运行状况监视和性能功能 调试支持 XML Web services 框架 可扩展的宿主环境和应用程序生命周期管理 可扩展的设计器环境 页和控件框架 ASP.NET 页和控件框架是一种编程框架,它在 Web 服务器上运行,可以动态地生成和呈现 ASP.NET 网页。可以从任何浏览器或客户端设备请求 ASP.NET 网页,ASP.NET 会向请求浏览器呈现标记(例如 HTML)。通常,您可以对多个浏览器使用相同的页,因为 ASP.NET 会为发出请求的浏览器呈现适当的标记。但是,您可以针对诸如 Microsoft Internet Explorer 6 的特定浏览器设计 ASP.NET 网页,并利用该浏览器的功能。ASP.NET 支持基于 Web 的设备(如移动电话、手持型计算机和个人数字助理 (PDA))的移动控件。 ASP.NET 网页是完全面向对象的。在 ASP.NET 网页,可以使用属性、方法和事件来处理 HTML 元素。ASP.NET 页框架为响应在服务器上运行的代码的客户端事件提供统一的模型,从而使您不必考虑基于 Web 的应用程序固有的客户端和服务器隔离的实现细节。该框架还会在页处理生命周期自动维护页及该页上控件的状态。有关更多信息,请参见 ASP.NET 网页概述。 使用 ASP.NET 页和控件框架还可以将常用的 UI 功能封装成易于使用且可重用的控件。控件只需编写一次,即可用于许多页并集成到 ASP.NET 网页。这些控件在呈现期间放入 ASP.NET 网页ASP.NET 页和控件框架还提供各种功能,以便可以通过主题和外观来控制网站的整体外观和感觉。可以先定义主题和外观,然后在页面级或控件级应用这些主题和外观。有关更多信息,请参见 ASP.NET 主题和外观概述。 除了主题外,还可以定义母版页,以使应用程序的页具有一致的布局。一个母版页可以定义您希望应用程序的所有页(或一组页)所具有的布局和标准行为。然后可以创建包含要显示的页特定内容的各个内容页。当用户请求内容页时,这些内容页与母版页合并,产生将母版页的布局与内容页的内容组合在一起的输出。有关更多信息,请参见 ASP.NET 母版页概述。 ASP.NET 编译器 所有 ASP.NET 代码都经过了编译,可提供强类型、性能优化和早期绑定以及其他优点。代码一经编译,公共语言运行库会进一步将 ASP.NET 编译为本机代码,从而提供增强的性能。 ASP.NET 包括一个编译器,该编译器将包括页和控件在内的所有应用程序组件编译成一个程序集,之后 ASP.NET 宿主环境可以使用该程序集来处理用户请求。有关更多信息,请参见 ASP.NET 编译概述。 安全基础结构 除了 .NET 的安全功能外,ASP.NET 还提供了高级的安全基础结构,以便对用户进行身份验证和授权,并执行其他与安全相关的功能。您可以使用由 IIS 提供的 Windows 身份验证对用户进行身份验证,也可以通过您自己的用户数据库使用 ASP.NET Forms 身份验证和 ASP.NET 成员资格来管理身份验证。此外,可以使用 Windows 组或您自己的自定义角色数据库(使用 ASP.NET 角色)来管理 Web 应用程序的功能和信息方面的授权。您可以根据应用程序的需要方便地移除、添加或替换这些方案。有关更多信息,请参见下列主题: ASP.NET 网站安全性 使用成员资格管理用户 使用角色管理授权 Forms 身份验证提供程序 ASP.NET 始终使用特定的 Windows 标识运行,因此,您可以通过使用 Windows 功能(例如 NTFS 访问控制列表 (ACL)、数据库权限等等)来保护应用程序的安全。有关 ASP.NET 标识的更多信息,请参见配置 ASP.NET 进程标识和 ASP.NET 模拟。 状态管理功能 ASP.NET

62,041

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧