本文转自:http://de.cel.blog.163.com/blog/static/5145123620110181003903/

类似于SQLHelper,只是这里引用的是MySql.Data类库,而不是System.Data.SqlClient;因为.Net框架里面并不包 含些类库,好在咱们有强大的网友有做好的MySql.Data类库。在网上一搜MySql.Data就可以找到的。注意一定要先添加对 MySql.Data的引用哦,接下来是MySQLHelper的类库代码。

using System.Data;
using MySql.Data.MySqlClient;

namespace MySQLHelper
{

/// <summary>

/// 基于MySQL的数据层基类

/// </summary>

/// <remarks>

/// 参考于MS Petshop 4.0

/// </remarks>

public abstract class MySqlHelper
    {

#region 数据库连接字符串

public static readonly string DBConnectionString =
System.Configuration.ConfigurationManager.ConnectionStrings["DBConnectionString"].ToString();

//public static readonly string DBConnectionString =
"Server=localhost;DataBase=menagerie;Uid=de.cel;Pwd=de.cel";  
//在MySql中localhost好像不能用"."代替,我试了一下,会出错。
        #endregion

#region PrepareCommand

/// <summary>

/// Command预处理

/// </summary>

/// <param name="conn">MySqlConnection对象</param>

/// <param name="trans">MySqlTransaction对象,可为null</param>

/// <param name="cmd">MySqlCommand对象</param>

/// <param name="cmdType">CommandType,存储过程或命令行</param>

/// <param name="cmdText">SQL语句或存储过程名</param>

/// <param name="cmdParms">MySqlCommand参数数组,可为null</param>

private static void PrepareCommand(MySqlConnection conn,
MySqlTransaction trans, MySqlCommand cmd, CommandType cmdType, string
cmdText, MySqlParameter[] cmdParms)
        {

if (conn.State != ConnectionState.Open)

conn.Open();

cmd.Connection = conn;

cmd.CommandText = cmdText;

if (trans != null)

cmd.Transaction = trans;

cmd.CommandType = cmdType;

if (cmdParms != null)
            {

foreach (MySqlParameter parm in cmdParms)

cmd.Parameters.Add(parm);

}

}

#endregion

#region ExecuteNonQuery

/// <summary>

/// 执行命令

/// </summary>

/// <param name="connectionString">数据库连接字符串</param>

/// <param name="cmdType">命令类型(存储过程或SQL语句)</param>

/// <param name="cmdText">SQL语句或存储过程名</param>

/// <param name="cmdParms">MySqlCommand参数数组</param>

/// <returns>返回受引响的记录行数</returns>

public static int ExecuteNonQuery(string connectionString, CommandType
cmdType, string cmdText, params MySqlParameter[] cmdParms)
        {

MySqlCommand cmd = new MySqlCommand();

using (MySqlConnection conn = new MySqlConnection(connectionString))
            {

PrepareCommand(conn, null, cmd, cmdType, cmdText, cmdParms);

int val = cmd.ExecuteNonQuery();

cmd.Parameters.Clear();

return val;

}

}

/// <summary>

/// 执行命令

/// </summary>

/// <param name="conn">Connection对象</param>

/// <param name="cmdType">命令类型(存储过程或SQL语句)</param>

/// <param name="cmdText">SQL语句或存储过程名</param>

/// <param name="cmdParms">MySqlCommand参数数组</param>

/// <returns>返回受引响的记录行数</returns>

public static int ExecuteNonQuery(MySqlConnection conn, CommandType
cmdType, string cmdText, params MySqlParameter[] cmdParms)
        {

MySqlCommand cmd = new MySqlCommand();

PrepareCommand(conn, null, cmd, cmdType, cmdText, cmdParms);

int val = cmd.ExecuteNonQuery();

cmd.Parameters.Clear();

return val;

}

/// <summary>

/// 执行事务

/// </summary>

/// <param name="trans">MySqlTransaction对象</param>

/// <param name="cmdType">命令类型(存储过程或SQL语句)</param>

/// <param name="cmdText">SQL语句或存储过程名</param>

/// <param name="cmdParms">MySqlCommand参数数组</param>

/// <returns>返回受引响的记录行数</returns>

public static int ExecuteNonQuery(MySqlTransaction trans, CommandType
cmdType, string cmdText, params MySqlParameter[] cmdParms)
        {

MySqlCommand cmd = new MySqlCommand();

PrepareCommand(trans.Connection, trans, cmd, cmdType, cmdText, cmdParms);

int val = cmd.ExecuteNonQuery();

cmd.Parameters.Clear();

return val;

}

#endregion

#region ExecuteScalar

/// <summary>

/// 执行命令,返回第一行第一列的值

/// </summary>

/// <param name="connectionString">数据库连接字符串</param>

/// <param name="cmdType">命令类型(存储过程或SQL语句)</param>

/// <param name="cmdText">SQL语句或存储过程名</param>

/// <param name="cmdParms">MySqlCommand参数数组</param>

/// <returns>返回Object对象</returns>

public static object ExecuteScalar(string connectionString, CommandType
cmdType, string cmdText, params MySqlParameter[] cmdParms)
        {

MySqlCommand cmd = new MySqlCommand();

using (MySqlConnection connection = new MySqlConnection(connectionString))
            {

PrepareCommand(connection, null, cmd, cmdType, cmdText, cmdParms);

object val = cmd.ExecuteScalar();

cmd.Parameters.Clear();

return val;

}

}

/// <summary>

/// 执行命令,返回第一行第一列的值

/// </summary>

/// <param name="connectionString">数据库连接字符串</param>

/// <param name="cmdType">命令类型(存储过程或SQL语句)</param>

/// <param name="cmdText">SQL语句或存储过程名</param>

/// <param name="cmdParms">MySqlCommand参数数组</param>

/// <returns>返回Object对象</returns>

public static object ExecuteScalar(MySqlConnection conn, CommandType
cmdType, string cmdText, params MySqlParameter[] cmdParms)
        {

MySqlCommand cmd = new MySqlCommand();

PrepareCommand(conn, null, cmd, cmdType, cmdText, cmdParms);

object val = cmd.ExecuteScalar();

cmd.Parameters.Clear();

return val;

}

#endregion

#region ExecuteReader

/// <summary>

/// 执行命令或存储过程,返回MySqlDataReader对象

/// 注意MySqlDataReader对象使用完后必须Close以释放MySqlConnection资源

/// </summary>

/// <param name="connectionString">数据库连接字符串</param>

/// <param name="cmdType">命令类型(存储过程或SQL语句)</param>

/// <param name="cmdText">SQL语句或存储过程名</param>

/// <param name="cmdParms">MySqlCommand参数数组</param>

/// <returns></returns>

public static MySqlDataReader ExecuteReader(string connectionString,
CommandType cmdType, string cmdText, params MySqlParameter[] cmdParms)
        {

MySqlCommand cmd = new MySqlCommand();

MySqlConnection conn = new MySqlConnection(connectionString);

try
            {

PrepareCommand(conn, null, cmd, cmdType, cmdText, cmdParms);

MySqlDataReader dr = cmd.ExecuteReader(CommandBehavior.CloseConnection);

cmd.Parameters.Clear();

return dr;

}

catch
            {

conn.Close();

throw;

}

}

#endregion

#region ExecuteDataSet

/// <summary>

/// 执行命令或存储过程,返回DataSet对象

/// </summary>

/// <param name="connectionString">数据库连接字符串</param>

/// <param name="cmdType">命令类型(存储过程或SQL语句)</param>

/// <param name="cmdText">SQL语句或存储过程名</param>

/// <param name="cmdParms">MySqlCommand参数数组(可为null值)</param>

/// <returns></returns>

public static DataSet ExecuteDataSet(string connectionString,
CommandType cmdType, string cmdText, params MySqlParameter[] cmdParms)
        {

MySqlCommand cmd = new MySqlCommand();

using (MySqlConnection conn = new MySqlConnection(connectionString))
            {

PrepareCommand(conn, null, cmd, cmdType, cmdText, cmdParms);

MySqlDataAdapter da = new MySqlDataAdapter(cmd);

DataSet ds = new DataSet();

da.Fill(ds);

conn.Close();

cmd.Parameters.Clear();

return ds;

}

}

#endregion

}//end class

}

[转]MySQLHelper类的更多相关文章

  1. PHP简单封装MysqlHelper类

    MysqlHelper.class.php 1: <?php 2:  3: /** 4: * Mysql数据帮助类 5: */ 6: class MysqlHelper 7: { 8: func ...

  2. MysqlHelper类

    连接方式:server=localhost;port=3306;userid=root;password=123456789;database=mysql;persist security info= ...

  3. 用于Mysql操作的MySqlHelper类

    using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Te ...

  4. C# 基于MySQL的数据层基类(MySQLHelper)

    这里介绍下比较简单的方式,引用MySql.Data.dll然后添加一个MySqlHelper类来对MySql数据库进行访问和操作. 1.将MySql.Data.dll引用到你的项目中 下载地址:MyS ...

  5. 在.NET连接MySQL以及封装好的MySQLHelper.cs

    1.首先上MySQL网站下驱动:http://www.mysql.com/products/connector/ 2.安装下载的安装包 3.我们在Visual Studio里创建一个Web Appli ...

  6. Java类的继承与多态特性-入门笔记

    相信对于继承和多态的概念性我就不在怎么解释啦!不管你是.Net还是Java面向对象编程都是比不缺少一堂课~~Net如此Java亦也有同样的思想成分包含其中. 继承,多态,封装是Java面向对象的3大特 ...

  7. java操作MySQL数据库(插入、删除、修改、查询、获取所有行数)

    插播一段广告哈:我之前共享了两个自己写的小应用,见这篇博客百度地图开发的两个应用源码共享(Android版),没 想到有人找我来做毕设了,年前交付,时间不是很紧,大概了解了下就接下了,主要用到的就是和 ...

  8. C# vs MySql

    MySqlHelper类 /// <summary> ///MySql操作类 /// </summary> public abstract class MySqlHelper ...

  9. .Net中如何使用MySql连接池

    提供一份官方的译文.翻译也挺辛苦的!! 6.4 Using Connector/Net with Connection Pooling 6.4在Connector/Net中使用连接池 The Conn ...

随机推荐

  1. Python 值传递和引用传递

    值传递和引用传递 參考地址:http://www.dataguru.cn/thread-489552-1-1.html python的值传递不会改变传入參数的值,而引用传递传入的是一个地址.有点相似c ...

  2. Codeforces 472D

    看官方题解提供的是最小生成树,怎么也想不明确.you can guess and prove it! 看了好几个人的代码.感觉实现思路全都不一样,不得不佩服cf题目想法的多样性 以下说说我自己的理解, ...

  3. view-activity跟控件在onkey事件上的传递关系

    android 中Activity跟View对于键盘的监听,主要有以下几个方法 //按键按下 public boolean onKeyDown(int keyCode, KeyEvent event) ...

  4. es7 --- 新特性

    ES7只有2个特性: includes() 指数操作符 不使用ES7 使用indexOf()验证数组中是否存在某个元素,这时需要根据返回值是否为-1来判断: let arr = ['react', ' ...

  5. Zabbix快速入门

    模板的管理与使用 一 模板 模板是zabbix的核心,因为模板继承了所有要监控的内容,以及所要展示的图形等等,zabbix的安装部署完成之后,自带了很多模板(网络设备模板,操作系统模板,常用应用软件模 ...

  6. 暑假集训-二分图,网络流,2-SAT

    匈牙利算法DFS bool dfs(int u){ ; i <= n; i++){ if(a[u][i] && !visit[i]){ visit[i] = true; || d ...

  7. private SortedDictionary<string, object> Dic_values = new SortedDictionary<string, object>();

    private SortedDictionary<string, object> Dic_values = new SortedDictionary<string, object&g ...

  8. javafx ComboBox Event and change cell color

    public class EffectTest extends Application { public static void main(String[] args) { launch(args); ...

  9. C/C++(函数)

    函数 函数三要素:函数名,参数,返回值 重点研究函数的输入输出 随机数函数 //产生一组随机数 #include<stdio.h> #include<stdlib.h> #in ...

  10. 用内置的库turtle来画一朵花,python3

    题目:用内置的库turtle来画一朵花 看了群主最后成像的图片,应该是循环了36次画方框,每次有10度的偏移. 当然不能提前看答案,自己试着写代码. 之前有用过海龟画图来画过五角星.奥运五环.围棋盘等 ...