首页 > 数据库技术 > 详细

C# MySql 操作类

时间:2015-01-19 23:33:05      阅读:459      评论:0      收藏:0      [点我收藏+]
/*
    MySql 类
 */
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using MySql.Data.MySqlClient;
using MySql.Data;
using System.Data;

namespace DbMysql
{
    public class CDbMysql
    {
        #region 字段设置
        /// <summary>
        /// 数据库连接-IP地址
        /// </summary>
        public string db_host { set; private get; }
        /// <summary>
        /// 数据库连接-用户名
        /// </summary>
        public string db_uname { set; private get; }
        /// <summary>
        /// 数据库连接-密码
        /// </summary>
        public string db_upswd { set;private get;}
        /// <summary>
        /// 数据库连接-数据库名称
        /// </summary>
        public string db_database { set; private get; }
        /// <summary>
        /// 数据库连接-端口
        /// </summary>
        public string db_prost { set; private get; }
        /// <summary>
        /// 数据库连接-数据库编码
        /// </summary>
        public string db_charset { set; private get; }
        /// <summary>
        /// 数据库连接-连接句柄
        /// </summary>
        private MySqlConnection db_header;
        /// <summary>
        /// 连接字符串
        /// </summary>
        private string dh_con_string { set; get; }

        public string DbError { private set; get; }
        #endregion


        /// <summary>
        /// 构造函数
        /// </summary>
        /// <param name="host">主机IP</param>
        /// <param name="uname">用户名</param>
        /// <param name="upassword">密码</param>
        /// <param name="prost">端口</param>
        /// <param name="charset">编码-默认utf8</param>
        public CDbMysql(string host, string uname, string upassword,string dbname, string prost, string charset = "utf8") {
            this.db_host = host;
            this.db_uname = uname;
            this.db_upswd = upassword;
            this.db_database = dbname;
            this.db_prost = prost;
            this.db_charset = charset;
           // User Id=root;Host=localhost;Database=studb;Password=root;Port=3307
            this.dh_con_string = string.Format("User Id={0};Host={1};Database={2};Password={3};Port={4}",this.db_uname,
                                               this.db_host,this.db_database,this.db_upswd,this.db_prost
                                               );
            
            this.DbConnection();
        }
        /// <summary>
        /// 连接数据库
        /// </summary>
        private void DbConnection(){
            this.db_header = new  MySqlConnection(this.dh_con_string);
        }
       /// <summary>
       /// 执行SQL语句
       /// </summary>
       /// <param name="QueryString"></param>
       /// <returns></returns>
        public int ExecuteSql(string QueryString) {
            try
                {
                    this.db_header.Open();
                    using (MySqlCommand comm = new MySqlCommand(QueryString, this.db_header)) {
                            int result = comm.ExecuteNonQuery();
                            this.DbClose(this.db_header);
                            return result;
               
                    }
                }
            catch (MySqlException ex)
            {
                this.DbError = ex.Message.ToString();
                return -1;
            }
            finally
            {
                this.DbClose(this.db_header);
            }
        }
        /// <summary>
        /// 返回DataTable
        /// </summary>
        /// <param name="SqlString"></param>
        /// <param name="TablName"></param>
        /// <returns></returns>
        public DataTable GetDataTable(string SqlString, string TablName) {
            try
            {
                this.db_header.Open();
                MySqlDataAdapter Da = new MySqlDataAdapter(SqlString, this.db_header);
                DataTable dt = new DataTable(TablName);
                Da.Fill(dt);
                return dt;
            }
            catch (MySqlException ex) {
                this.DbError = ex.Message.ToString();
                return null;
            }
            
        }
        /// <summary>
        /// 返回DataReader对象
        /// </summary>
        /// <param name="SqlString"></param>
        /// <returns></returns>
        public MySqlDataReader GetDataReader(string SqlString) {
            try
            {
                this.db_header.Open();
                MySqlCommand comm = new MySqlCommand(SqlString, this.db_header);
                MySqlDataReader dread = comm.ExecuteReader(CommandBehavior.Default);
                return dread;
            }
            catch (MySqlException ex)
            {
                this.DbError = ex.Message.ToString();
                return null;
            }
           
        }
        /// <summary>
        /// 获取DataAdapter对象
        /// </summary>
        /// <param name="SqlString"></param>
        /// <returns></returns>
        private MySqlDataAdapter GetDataAdapter(string SqlString) {
            try
            {
                this.db_header.Open();
                MySqlDataAdapter dadapter = new MySqlDataAdapter(SqlString, this.db_header);
                return dadapter;
            }
            catch (MySqlException ex)
            {
                this.DbError = ex.Message.ToString();
                return null;
            }
            
        }
        /// <summary>
        /// 返回DataSet对象
        /// </summary>
        /// <param name="SqlString"></param>
        /// <param name="TableName"></param>
        /// <returns></returns>
        public DataSet GetDataSet(string SqlString,string TableName) {
            try
            {
                this.db_header.Open();
                MySqlDataAdapter Da = this.GetDataAdapter(SqlString);
                DataSet ds = new DataSet();
                Da.Fill(ds, TableName);
                return ds;
            }
            catch (MySqlException ex) {
                this.DbError = ex.Message.ToString();
                return null;
            }
        }
        /// <summary>
        /// 获取一条数据
        /// </summary>
        /// <param name="SqlString"></param>
        /// <returns></returns>
        public string GetOne(string SqlString) {
            string result = null;
            try
            {  
                this.db_header.Open();
                MySqlCommand comm = new MySqlCommand(SqlString, this.db_header);
                MySqlDataReader dr = comm.ExecuteReader();
                if (dr.Read())
                {
                    result = dr[0].ToString();
                    dr.Close();
                }
                else
                {
                    result = null ;
                    dr.Close();
                }
                
            }
            catch (MySqlException ex) {
                this.DbError = ex.Message.ToString();
            }
            return result;
        }
        /// <summary>
        /// 连接测试
        /// </summary>
        /// <returns></returns>
        public bool TestConn() {
            try {
                this.db_header.Open();
                return true;
            }
            catch (MySqlException ex)
            {
                this.DbError = ex.Message.ToString();
                return false;
            }
        }
        /// <summary>
        /// 关闭数据库句柄
        /// </summary>
        public void DbClose(MySqlConnection DbHeader) {
            if (DbHeader != null) {
                this.db_header.Close();
                this.db_header.Dispose();
            };

            GC.Collect();
        }

    }
}

 

C# MySql 操作类

原文:http://www.cnblogs.com/flay/p/4234952.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!