文档章节

C#创建数据库 附加数据库等操作

深圳大道
 深圳大道
发布于 2016/12/29 15:25
字数 600
阅读 15
收藏 0
/// <summary>
				/// 附加数据库方法
				/// </summary>
				/// <param name="strSql">连接数据库字符串,连接master系统数据库</param>
				/// <param name="DataName">数据库名字</param>
				/// <param name="strMdf">数据库文件MDF的路径</param>
				/// <param name="strLdf">数据库文件LDF的路径</param>
				/// <param name="path">安装目录</param>
				private   void  CreateDataBase( string  strSql, string  DataName,  string  strMdf,  string  strLdf, string  path)
				{
				   SqlConnection myConn = new SqlConnection(strSql);
				   String str = null ;
				   try
				   {
				      str = " EXEC sp_attach_db @dbname='"+DataName+"',@filename1='"+strMdf+"',@filename2='"+strLdf+"'";
				      SqlCommand myCommand = new SqlCommand(str, myConn);
				      myConn.Open();
				      myCommand.ExecuteNonQuery();
				      MessageBox.Show("数据库安装成功!点击确定继续");//需Using System.Windows.Forms
				   }
				   catch(Exception e)
				   {
				      MessageBox.Show("数据库安装失败!" + e.Message+"\n\n"+"您可以手动附加数据");
				      System.Diagnostics.Process.Start(path);//打开安装目录
				   }
				   finally
				   {
				      myConn.Close();
				   }
				}
				
				public override void Install(System.Collections.IDictionary stateSaver)
				{
				   string server = this.Context.Parameters["server"];//服务器名称
				    string uid = this.Context.Parameters["user"];//SQlServer用户名
				    string pwd = this.Context.Parameters["pwd"];//密码
				    string path = this.Context.Parameters["targetdir"];//安装目录
				    string strSql = "server=" + server + ";uid=" + uid + ";pwd=" + pwd + ";database=master";//连接数据库字符串
				    string DataName = "JXC";//数据库名
				    string strMdf = path + @"JXC.mdf";//MDF文件路径,这里需注意文件名要与刚添加的数据库文件名一样!
				    string strLdf = path + @"jxc_log.ldf";//LDF文件路径
				    base.Install(stateSaver);
				   this.CreateDataBase(strSql, DataName, strMdf, strLdf, path);//开始创建数据库
				} 


 				/// <summary>
        /// 测试连接
        /// </summary>
        /// <param name="serverName"></param>
        /// <param name="dbName"></param>
        /// <param name="userName"></param>
        /// <param name="password"></param>
        private SqlConnection TestConnection(string serverName, string dbName, string userName, string password)
        {
            string connectionString = GetConnectionString(serverName, dbName, userName, password);
            SqlConnection connection = new SqlConnection(connectionString);
            try
            {
                if (connection.State != ConnectionState.Open)
                {
                    connection.Open();
                }
                return connection;
            }
            catch
            {
                CloseConnection(connection);
                throw new InstallException("安装失败!\n数据库配置有误,请正确配置信息!");
            }
        }


        /// <summary>
        /// 得到连接字符串
        /// </summary>
        /// <param name="serverName"></param>
        /// <param name="dbName"></param>
        /// <param name="userName"></param>
        /// <param name="password"></param>
        /// <returns></returns>
        private string GetConnectionString(string serverName, string dbName, string userName, string password)
        {
            string connectionString = "Data Source={0};Initial Catalog={1};User ID={2};Password={3}";
            connectionString = string.Format(connectionString, serverName, dbName, userName, password);
            return connectionString;
        }

        /// <summary>
        /// 创建数据库
        /// </summary>
        /// <param name="serverName"></param>
        /// <param name="dbName"></param>
        /// <param name="userName"></param>
        /// <param name="password"></param>
        /// <param name="connection"></param>
        /// <param name="stateSaver"></param>
        public int CreateDataBase(SqlConnection connection)
        {
            int result = -1;
            connection.ChangeDatabase("master");
            string createDBSql = @" if Exists(select 1 from sysdatabases where [name]=N'{0}')
                                    begin
                                    drop database {0}
                                    end
                                    GO 
                                    CREATE DATABASE {0} ";
            createDBSql = string.Format(createDBSql, _dbName);

            //因为有Go在SQLCommand中不认识,所以以Go为分隔符取sql语句

            char[] split = new char[] { 'G', 'O' };
            string[] sqlList = createDBSql.Split(split);

            SqlCommand command = null;
            try
            {
                command = connection.CreateCommand();
                command.CommandType = System.Data.CommandType.Text;
                foreach (string sqlItem in sqlList)
                {
                    if (sqlItem.Length > 2)
                    {
                        command.CommandText = sqlItem;
                        result = command.ExecuteNonQuery();
                    }
                }
                return result;
            }
            catch
            {
                CloseConnection(connection);
                command.Dispose();
                throw new InstallException("安装失败!\n数据库配置不正确!");
            }
        }

        /// <summary>
        /// 分隔SQL语句
        /// </summary>
        /// <param name="sql"></param>
        /// <returns></returns>
        private string[] splitSql(string sql)
        {
            Regex regex = new Regex("^GO", RegexOptions.IgnoreCase | RegexOptions.Multiline);
            string[] sqlList = regex.Split(sql.ToUpper());
            return sqlList;
        }

本文转载自:http://blog.csdn.net/smartsmile2012/article/details/8782522

深圳大道
粉丝 3
博文 877
码字总数 0
作品 0
深圳
架构师
私信 提问
SQL Server数据库附加之后只读或是失败的破解

SQL Server数据库附加之后只读或是失败的破解 发布时间:2010.07.22 14:00 来源:51cto 作者:51cto 我们今天主要向大家讲述的是SQL Server数据库附加后只读或是失败解决方法及代码实现,相信...

renwuzhongguo
2014/10/16
0
0
sqlite view定义查询页面

下面想象一个这样的场景,你的数据库有一个表中储存有用户信息,姑且称为user表。 .schema user CREATE TABLE user(id integer,name text,telphone text,unique(id)); 表user中储存有 id: ...

quanwei9958
2014/12/08
110
0
[Unity]SQLite-C#调用 SQLite数据库-Unity操作

SQLite数据库-Unity操作 项目开发的时候,经常会遇到的一种需求,数据存储 离线缓存的数据类型很多,大致分成两类 字符串文本数据 多媒体数据 字符串数据的类型只有字符串,但是结构有很多:...

浩浩老师
2015/10/14
1K
0
【Sql Server】3.管理数据库

一、数据库组成 表、视图(对多个表中的数据进行组合)、存储过程、触发器、用户与角色(在‘数据库xx/安全性’下)、其他数据库部分 二、使用管理工具创建数据库 1. 运行Microsoft SQL Ser...

Jannie_xx
2014/05/23
0
0
携程 DAL 框架--Ctrip DAL

简介 Ctrip DAL是携程框架部开发的数据库访问框架,支持代码生成和水平扩展。其由携程技术中心框架部DAL团队开发,历经3年不断打磨,并在长期的实际使用中基于大量的用户反馈不断优化。 背景...

赫杰辉
2016/09/14
5.6K
4

没有更多内容

加载失败,请刷新页面

加载更多

java通过ServerSocket与Socket实现通信

首先说一下ServerSocket与Socket. 1.ServerSocket ServerSocket是用来监听客户端Socket连接的类,如果没有连接会一直处于等待状态. ServetSocket有三个构造方法: (1) ServerSocket(int port);...

Blueeeeeee
今天
6
0
用 Sphinx 搭建博客时,如何自定义插件?

之前有不少同学看过我的个人博客(http://python-online.cn),也根据我写的教程完成了自己个人站点的搭建。 点此:使用 Python 30分钟 教你快速搭建一个博客 为防有的同学不清楚 Sphinx ,这...

王炳明
昨天
5
0
黑客之道-40本书籍助你快速入门黑客技术免费下载

场景 黑客是一个中文词语,皆源自英文hacker,随着灰鸽子的出现,灰鸽子成为了很多假借黑客名义控制他人电脑的黑客技术,于是出现了“骇客”与"黑客"分家。2012年电影频道节目中心出品的电影...

badaoliumang
昨天
14
0
很遗憾,没有一篇文章能讲清楚线程的生命周期!

(手机横屏看源码更方便) 注:java源码分析部分如无特殊说明均基于 java8 版本。 简介 大家都知道线程是有生命周期,但是彤哥可以认真负责地告诉你网上几乎没有一篇文章讲得是完全正确的。 ...

彤哥读源码
昨天
15
0
jquery--DOM操作基础

本文转载于:专业的前端网站➭jquery--DOM操作基础 元素的访问 元素属性操作 获取:attr(name);$("#my").attr("src"); 设置:attr(name,value);$("#myImg").attr("src","images/1.jpg"); ......

前端老手
昨天
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部