大学IT网 - 最懂大学生的IT学习网站! QQ资料交流群:367606806
当前位置:大学IT网 > C#技巧 > .net安装包自动安装Mysql数据库

.net安装包自动安装Mysql数据库(2)

关键词:安装包安装数据库netMysql  阅读(7590) 赞(21)

[摘要]本文是对.net安装包自动安装Mysql数据库的讲解,与大家分享。

using System;
using System.Collections;
using System.Collections.Generic;
using System.ComponentModel;
using System.Configuration.Install;
using System.Linq;

using MySql.Data.MySqlClient;
using System.IO;
using System.Threading;

namespace inserterDb
{
    [RunInstaller(true)]
    public partial class Installer1 : System.Configuration.Install.Installer
    {
        public Installer1()
        {
            InitializeComponent();
        }

        public override void Install(IDictionary stateSaver)
        {
            base.Install(stateSaver);

            InsertMySql();
            CreatDataBase();
            Log("安装成功!");
        }

       //安装mysql
        protected void InsertMySql()
        {
            string physicalRoot = this.Context.Parameters["targetdir"]; // 安装物理路径 C:\program\microp
            string appPath = physicalRoot + "\\MySQL Server 5.5\\";

            //1.修改my.ini配置  为防止本机已装mysql,特修改my.ini中端口号为3307
            string iniFile = File.ReadAllText(appPath + "my.ini");
            iniFile = iniFile.Replace("%BaseDir%", physicalRoot.Replace("\\", "/")); //%BaseDir%为my.ini中自定义的目录参数
            File.WriteAllText(appPath + "my.ini", iniFile);

            Log("创建win服务……");
            //2.创建win服务
            string info1 = CommandHelper.Execute(appPath + "bin\\mysqld.exe", " install MySQL2 --defaults-file=\"" + appPath + "my.ini\"", 0);
            Log(info1);
            Thread.Sleep(3000);
            Log("使用net start启动服务");
            //3.启动服务
            string info2 = CommandHelper.Execute("net start MySQL2", 0);
            Log(info2);

            Log("启动服务完成!");
            Thread.Sleep(5000);
            MySqlConnection con = new MySqlConnection("Data Source='localhost';Port='3307';Database='';User Id='root';Password='';");
            try
            {
                con.Open();
                con.Close();
                Log("连接成功!");
            }
            catch (Exception ex)
            {
                Log("连接失败!" + ex.Message);
            }
        }
        //创建数据库并初始化表
        protected void CreatDataBase()
        {
            string physicalRoot = this.Context.Parameters["targetdir"]; // 安装物理路径 C:\program\microp
            string mysqlcon = "Data Source='localhost';Port='3307';Database='{0}';User Id='root';Password='';";

            MySqlConnection conn = new MySqlConnection(string.Format(mysqlcon, ""));
            FileInfo file = new FileInfo(physicalRoot + "\\DBInit\\yourDB.sql");  //filename是sql脚本文件路径。
            string sql = file.OpenText().ReadToEnd();

            try
            {
                MySqlScript script = new MySqlScript(conn);
                script.Query = sql;
                int count = script.Execute();
                Log("数据库初始化完成!");

                MySqlConnection con2 = new MySqlConnection(string.Format(mysqlcon, "yourDB"));
                con2.Open();
                MySqlCommand dbcom = new MySqlCommand("select count(*) from t_image", con2);
                dbcom.ExecuteScalar();
                con2.Close();
                Log("数据库创建OK!");

                //修改config.xml中的数据库链接地址
                
            }
            catch (Exception ex2)
            {
                Log("数据库创建失败!" + ex2.Message);
            }


        }

        //写日志
        protected void Log(string line)
        {
            string physicalRoot = this.Context.Parameters["targetdir"]; // 安装物理路径 C:\program\microp
            string filePath = physicalRoot + "Install_log.txt";
            if (File.Exists(filePath))
            {
                File.AppendAllLines(filePath, new string[] { DateTime.Now.ToString("[yyyy-MM-dd HH:mm:ss] ") + line });
            }
            else
            {
                File.WriteAllLines(filePath, new string[] { DateTime.Now.ToString("[yyyy-MM-dd HH:mm:ss] ") + line });
            }
        }
    }
}

此类override void Install方法,当程序安装完后,立即启动数据库的安装。

用代码安装MySql数据库安装步骤是:

1)修改my.ini配置 为防止本机已装mysql,特修改my.ini中端口号为3307

my.ini中的路径应该设置为安装程序的安装目录,这个目录是用户自定义的,可以通过设置Setup的customActionData属性来传递参数,详见后文介绍。

2)调用“mysqld.exe -install ”命令安装mysql数据库服务

3)使用net start启动Mysql服务

4)验证数据库安装结果

5)执行初始化脚本,初始化数据库

5.在Setup中关联安装MySql数据库的自定义操作

右键单击“setup1”项目,选择“视图”--“自定义操作” 在“安装”文件夹下右键选“添加自定义操作” 选择第4步制作的InserterDb的类库项目。

设置刚添加的自定义操作的属性,CustomActionData为 /targetdir="[TARGETDIR]\"

这里的targetdir是自定义的参数名称,目的是获取用户选择的程序安装路径,用于修改Mysql配置文件中的%BaseDir%参数。

测试源码下载:Source

注意,由于mysql文件太大,该目录只留目录名,文件自己拷贝进去即可。

«上一页12下一页»


相关评论