当前位置:Gxlcms > 数据库问题 > C#使用开源驱动连接操作MySQL数据库

C#使用开源驱动连接操作MySQL数据库

时间:2021-07-01 10:21:17 帮助过:19人阅读


using System;

using System.IO;

using MySQLDriverCS; //引入的命名空间就这个

using System.Data.Common;

namespace cc.unmi

{

public class Program

{

public static void Main(string[] args)

{

//MySQLDriverCS 有了 MySQLConnectionStringBuilder 和 MySQLConnectionString 来构造连接字符串

//其实反而有点故弄玄虚,也许是以前直接用连接字符串习惯了

MySQLConnectionString conStr = new MySQLConnectionString(“localhost”, “unmi_db”, “unmi”, “xxxxxx”);

//从 MySQLConnectionStringBuilder 来看似乎可支持的属性较少,不知道连接池那些功能怎么样

//string connStr = “Data Source=unmi_db;Password=xxxxxx;User ID=unmi;Location=localhost;Port=3306;Extended Properties=”;

MySQLConnection conn = new MySQLConnection(conStr.AsString); //或 new MySQLConnection(connStr);

conn.Open();

//参数用 @, 同样支持 ? 的方式, 应该也是不推荐用 ? 的形式

//string sql = “update wp_options set option_value=’http://unmi.cc’ where option_id=?id and <a href=”mailto:option_name=@name”>option_name=@name</a>”;

string sql = “select option_name from wp_options where option_id=?id and <a href=”mailto:option_name=@name”>option_name=@name</a>”;

MySQLCommand com = new MySQLCommand(sql, conn);

MySQLParameter paraId = new MySQLParameter(“?id”, 1);

MySQLParameter paraName = new MySQLParameter(“@name”, “siteurl”);

//其实是加在 MySQLParameterCollection 里的

//看起来与 AddWithValue() 有异曲同功之妙,比如可写成 com.Parameters.Add(new MySQLParameter(“@id”,1);

com.Parameters.Add(paraId);

com.Parameters.Add(paraName);

//如果是查询

//MySQLDataReader dr = com.ExecuteReaderEx();//执行 ExecuteReaderEx() 返回的才是 MySQLDataReader

DbTransaction trans = conn.BeginTransaction(); //开启事物

try

{

//com.ExecuteNonQuery();

//还要执行更多的语句时应使用事物

Console.WriteLine(com.ExecuteScalar().ToString());

trans.Commit();

}

catch (MySQLException ex)

{

Console.WriteLine(ex.Message);

trans.Rollback();

}

finally

{

conn.Close();

}

Console.ReadKey();

}

}

}

虽说那个驱动文件名中有 DotNet2.0 字样,应该只要是 2.0 及以上的 .Net 运行时就行的,我是在 32 位的 XP 下,Visual Studio 2008 中,用 .Net 3.5 来跑的,没有问题。

备注一下,在我家里的电脑上却是运行不起来,提示是:


代码如下:


{“Could not load file or assembly ‘MySQLDriverCS, Version=3.0.1735.36021, Culture=neutral, PublicKeyToken=172f94dfb0faf263’ or one of its dependencies. An attempt was made to load a program with an incorrect format.”}

又是我那可恶的 64 位 XP,它只能支持 32 位的应用,与官版的驱动表现不一样。官版的 MSI 程序不能在我的 64 位系统下安装,但安装包中的 .dll 是可在 64 位下用。而这个版本的驱动是能安装,但用起来告诉我不行,明摆着是甩我。其实在下载驱动的网页上有注明用了 32 位的各种 Winows 操作系统云云。

最后简单说下与官版的驱动的少许差异,连接字符串上没有官版驱动丰富,且不知对连接池的支持如何。在用参数化查询设置参数时,虽然比标签的 ADO.Net 方便,便比起官版的可用 AddWithValue() 方法稍微逊色。再就是在 64 位下根本无法运行,这可不能不算是个致使伤,服务器下 64 位系统在所难免。

然而这个开源驱动也有些独到之处,那就是它提供的 MySQLInsertCommand、MySQLSelectCommand、MySQLUpdateCommand 和 MySQLDeleteCommand 类方便了数据操作,不需要你显式的去写 SQL 语句,很像 WordPress 的 $wpdb 中相应的几个函数:$wpdb->insert()、$wpdb->query()、$wpdb->update() 和 $wpdb->delete()。

本不应该把这个驱动这么鲜明的几个特性放后面的。大概看下这几个函数的操作:


代码如下:


new MySQLInsertCommand(

dbCon,//连接

new object[,] { //字段名及对应值

{“SettingID”,100},

{“SettingValue”,”http://www.jb51.net”}

},

“Settings” //表名

); //new 后即执行,可用 bSuccess 与 Query 属性分别获得成功与否及相应的 SQL

//这个 MySQLSelectCommand 有点让人蛋疼,还不如直接 SQL 痛快

DataTable dt = new MySQLSelectCommand(dbCon, //连接

new string[] { “SettingID”, “SettingValue” },//要查询的字段列表

new string[] { “Settings” }, // 要查询的表,可以多个

new object[,] { { “SettingID”, “=”, 100 } },//条件

null,

null //后面还可以有 limit, distinct 等指令及参数

).Table; //获得 DataTable

//更新时用这种方式还算方便

new MySQLUpdateCommand(dbCon,

new object[,] { { “SettingValue”, “http://www.jb51.net” } },

“Settings”,

new object[,] { { “SettingID”, “=”, 100 } },

null

); //new 后即执行,可用 bSuccess 与 Query 属性分别获得成功与否及相应的 SQL

//参数与 MySQLUpdateCommand 的后四个相同

new MySQLDeleteCommand(dbCon, “Trash”, null, null);

除声明外,跑步客文章均为原创,转载请以链接形式标明本文地址
  C#使用开源驱动连接操作MySQL数据库

本文地址:  http://www.paobuke.com/develop/c-develop/pbk23134.html






相关内容

技术分享图片C#??Word×a??3éPDF·?·¨??×ü(?ùóúOfficeoíWPS)技术分享图片C#byte数组与Image的相互转换实例代码技术分享图片C#读取XML的三种实现方式技术分享图片利用C#实现网络爬虫
技术分享图片C#自定义DataGridViewColumn显示TreeView技术分享图片C#遍历操作系统下所有驱动器的方法技术分享图片C#提示:“在证书存储区中找不到清单签名证书”的解决方法技术分享图片Repeater中添加按钮实现点击按钮获取某一行数据的方法

C#使用开源驱动连接操作MySQL数据库

标签:extend   字符   ibm   public   服务   字符串   签名   reader   could not   

人气教程排行