|
本帖最后由 youzi 于 2013-9-4 09:30 编辑
系统 window7 32位,64位,XP 都做过测试,可正常连接
开发环境VS2005
必须要用驱动,附件中有驱动,如若远程连接,得确保MYSQL有远程连接的授权(附件太大,有需要的朋友可以跟我要,自己去下载 mysql-connector-net-6.6.5.msi 也可以)
不同版本的驱动不一定可以支持远程连接,附件中的驱动可以的
1.在MYSQL 中读取表的名称是不区分大小写, 但是试图名是区分大小写的
2.MYSQL 句子和SQL差不多,SQL中F5执行 MYSQL 中F8执行,我对MYSQL不是很数据,反正也是只读取数据用,所以我关心的是连接数据库问题,最近做了个项目用到的,写出来与有需要的分享一下,我遇到的最多问题就是驱动用的不对,老是连接不上远程的MYSQL问题.试了好多次,目前的这个还行,希望有帮助
(连接MYSQL方式有好几种,这只是其中之一,只用的驱动不一样,其实写起来差不多)
[code=csharp]using System;
using System.Collections.Generic;
using System.Text;
using MySql.Data;
using MySql.Data.MySqlClient;//在项目中添加引用
using System.Data;
namespace PublicClass
{
/// <summary>
/// MySQL类 MySqlClient连接
/// </summary>
public class MySQLDataHelper
{
private MySqlConnection conn = null;
private MySqlCommand cmd = null;
private MySqlDataReader sdr;
private MySqlDataAdapter sda = null;
string pathxmlName = "Configure.xml";
string tablename = "SQLyogTable";
//远程odbc连接mysql数据库
//ODBCDATA odbcdata = new ODBCDATA();
/// <summary>
///
/// </summary>
public MySQLDataHelper()
{
string connStr = "server=" + 主机地址 + ";port=" +
端口号一般是3306 + ";user id=" +
用户名 + ";password=" +
密码 + ";database=" +
数据库名称 + ";Max Pool Size=512(此处为最大连接池,可以用写这以牺牲性能为代价的)";
conn = new MySqlConnection(connStr); //数据库连接
}
/// <summary>
/// 打开数据库链接
/// </summary>
/// <returns></returns>
private MySqlConnection GetConn()
{
if (conn.State == ConnectionState.Closed)
{
conn.Open();
}
return conn;
}
/// <summary>
/// 关闭数据库链接
/// </summary>
private void GetConnClose()
{
if (conn.State == ConnectionState.Open)
{
conn.Close();
}
}
/// <summary>
/// 执行不带参数的增删改SQL语句或存储过程
/// </summary>
/// <param name="cmdText">增删改SQL语句或存储过程的字符串</param>
/// <param name="ct">命令类型</param>
/// <returns>受影响的函数</returns>
public int ExecuteNonQuery(string cmdText, CommandType ct)
{
int res;
using (cmd = new MySqlCommand(cmdText, GetConn()))
{
cmd.CommandType = ct;
res = cmd.ExecuteNonQuery();
}
return res;
}
/// <summary>
/// 执行带参数的增删改SQL语句或存储过程
/// </summary>
/// <param name="cmdText">增删改SQL语句或存储过程的字符串</param>
/// <param name="paras">往存储过程或SQL中赋的参数集合</param>
/// <param name="ct">命令类型</param>
/// <returns>受影响的函数</returns>
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;
}
/// <summary>
/// 执行不带参数的查询SQL语句或存储过程
/// </summary>
/// <param name="cmdText">查询SQL语句或存储过程的字符串</param>
/// <param name="ct">命令类型</param>
/// <returns>查询到的DataTable对象</returns>
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;
}
/// <summary>
/// 执行带参数的查询SQL语句或存储过程
/// </summary>
/// <param name="cmdText">查询SQL语句或存储过程的字符串</param>
/// <param name="paras">参数集合</param>
/// <param name="ct">命令类型</param>
/// <returns></returns>
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;
}
/// <summary>
/// 执行指定数据库连接字符串的命令,返回DataSet.
/// </summary>
/// <param name="strSql">一个有效的数据库连接字符串</param>
/// <returns>返回一个包含结果集的DataSet</returns>
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;
}
}
}
[/code]
|
|