您现在的位置: 无忧电子商务网 >> 信息学院 >> 程序开发 >> asp.net >> 正文

.net打包自动安装数据库

作者:作者:未…    信息学院来源:网络收集    点击数:    更新时间:2006-8-28 我要参与讨论

  r.ReadToEnd(); 
   } 
   catch (Exception ex) 
   { 
    Console.Write("In GetSql:"+ex.Message); 
    throw ex; 
   } 
  } 
  private void ExecuteSql(string DataBaseName,string Sql) 
  {
   SqlConnection sqlConnection1=new SqlConnection();
   sqlConnection1.ConnectionString =string.Format("server={0}; user id={1}; password={2}; Database=master",this.Context.Parameters["server"],this.Context.Parameters["user"],this.Context.Parameters["pwd"]);
   System.Data.SqlClient.SqlCommand Command = new System.Data.SqlClient.SqlCommand(Sql,sqlConnection1); 
   try 
   {
    Command.Connection.Open(); 
    Command.Connection.ChangeDatabase(DataBaseName); 
   
    Command.ExecuteNonQuery(); 
   } 
   catch(Exception ex) 
   { 
    Console.Write("In exception handler :"+ex.Message); 
   }
   finally 
   { 
    Command.Connection.Close(); 
   } 
  } 

  protected void AddDBTable(string strDBName) 
  { 
   try 
   {     
    ExecuteSql("master","CREATE DATABASE "+ strDBName);
    ExecuteSql(strDBName,GetSql("sql.txt")); 
    ExecuteSql("master","exec sp_addlogin 'myoamaster','myoamaster','"+strDBName+"',Null,Null");
    ExecuteSql(strDBName,"EXEC sp_grantdbaccess 'myoamaster', 'myoamaster'");
    ExecuteSql(strDBName,"exec sp_addrolemember 'db_owner','myoamaster'");
   } 
   catch(Exception ex) 
   { 
    Console.Write("In exception handler :"+ex.Message); 
   } 
  } 
  public override void Install(System.Collections.IDictionary stateSaver) 
  { 
   base.Install(stateSaver); 
   AddDBTable(this.Context.Parameters["dbname"]); 
  } 
 }
}
这里有个sql.txt是数据库的sql脚本,当然可以调用osql来执行sql脚本,其实是一样的。
打包的时候必须把sql.txt文件加进来,否则不会执行。
如果你想附加数据库的mdf文件和ldf文件,用下面这段程序:
private void CreateDataBase(string strSql,string DataName,string strMdf,string strLdf)
  {
   String str;
   SqlConnection myConn = new SqlConnection (strSql);
   //EXEC sp_detach_db @dbname = 'BX_FreightMileage_2'//需要先将数据库分离出来
   str = "EXEC sp_attach_db @dbname = '"+ DataName +"', @filename1 = '"+ strMdf +"',@filename2='"+strLdf+"'";
   Sq

上一页  [1] [2] [3] [4] 下一页

在google里搜索更多.net打包自动安装数据库

Google
Web www.51ec.org
  • 上一篇信息学院:

  • 下一篇信息学院:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    我来说两句 对此文章发表了评论
      昵 称: *必填    ·注册用户·
      评 分: 1分 2分 3分 4分 5分     严禁发表危害国家安全、政治、黄色淫秽等内容的评论,用户需对自己在使用本网站服务过程中的行为承担法律责任。本站管理员有权保留或删除评论内容,评论内容只代表机友个人观点,与本网站立场无关。  
    评 论
    内 容

     
    评论列表 (最新 评论仅限网友观点!)

    供求信息




    | 设为首页 | 加入收藏 | 关于我们 | 广告服务 | 联系方式 | 友情链接 | 版权申明