winform连mysql的驱动很多,开始学把我弄糊涂了,就用connector/.net就好
以下为常用的datahelper类,虽说和java类似,还是有些不一样的地方,自己体会。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Text;
using MySql.Data;
using MySql.Data.MySqlClient;//在项目中添加引用
using System.Data;
namespace JCsystem_teacher
{
class MySQLDataHelper
{
private MySqlConnection conn = null;
private MySqlCommand cmd = null;
private MySqlDataReader sdr;
private MySqlDataAdapter sda = null;
public MySQLDataHelper()
{
string connStr = "Server=127.0.0.1;Port=3306;Database=kcd;Uid=root;Pwd=root;";
conn = new MySqlConnection(connStr); //数据库连接
}
///
/// 打开数据库链接
///
///
private MySqlConnection GetConn()
{
if (conn.State == ConnectionState.Closed)
{
conn.Open();
}
return conn;
}
///
/// 关闭数据库链接
///
private void GetConnClose()
{
if (conn.State == ConnectionState.Open)
{
conn.Close();
}
}
///
/// 执行不带参数的增删改SQL语句或存储过程
///
/// 增删改SQL语句或存储过程的字符串
/// 命令类型
/// 受影响的函数
public int ExecuteNonQuery(string cmdText, CommandType ct)
{
int res;
using (cmd = new MySqlCommand(cmdText, GetConn()))
{
cmd.CommandType = ct;
res = cmd.ExecuteNonQuery();
}
return res;
}
///
/// 执行带参数的增删改SQL语句或存储过程
///
/// 增删改SQL语句或存储过程的字符串
/// 往存储过程或SQL中赋的参数集合
/// 命令类型
/// 受影响的函数
public int ExecuteNonQuery(string cmdText, MySqlParameter[] paras,CommandType ct)
{
int res;
using (cmd = new MySqlCommand(cmdText, GetConn()))
{
cmd.CommandType = ct;
cmd.Parameters.AddRange(paras);
res = cmd.ExecuteNonQuery();
}
return res;
}
///
/// 执行不带参数的查询SQL语句或存储过程
///
/// 查询SQL语句或存储过程的字符串
/// 命令类型
/// 查询到的DataTable对象
public DataTable ExecuteQuery(string cmdText, CommandType ct)
{
DataTable dt = new DataTable();
cmd = new MySqlCommand(cmdText, GetConn());
cmd.CommandType = ct;
using (sdr = cmd.ExecuteReader(CommandBehavior.CloseConnection))
{
dt.Load(sdr);
}
return dt;
}
///
/// 执行带参数的查询SQL语句或存储过程
///
/// 查询SQL语句或存储过程的字符串
/// 参数集合
/// 命令类型
///
public DataTable ExecuteQuery(string cmdText, MySqlParameter[] paras,CommandType ct)
{
DataTable dt = new DataTable();
cmd = new MySqlCommand(cmdText, GetConn());
cmd.CommandType = ct;
cmd.Parameters.AddRange(paras);
using (sdr = cmd.ExecuteReader(CommandBehavior.CloseConnection))
{
dt.Load(sdr);
}
return dt;
}
///
/// 执行指定数据库连接字符串的命令,返回DataSet.
///
/// 一个有效的数据库连接字符串
/// 返回一个包含结果集的DataSet
public DataSet ExecuteDataset(string strSql)
{
DataSet ds = new DataSet();
sda = new MySqlDataAdapter(strSql, GetConn());
try
{
sda.Fill(ds);
}
catch (Exception ex)
{
throw ex;
}
finally
{
GetConnClose();
}
return ds;
}
}
}