MySQL_Illegal mix of collations

MySQL_Illegal mix of collations,第1张

序言

两个表进行关联查询的时候,突然报错,第一次遇到,遂记录一下。

错误如下:

MySQL_Illegal mix of collations (utf8mb4_unicode_ci,IMPLICIT) and (utf8mb4_general_ci,IMPLICIT) for operation '='

分析

MySQL的collation是字符序的意思。字符类型,有多个字符序。

mysql的字符序遵从命名惯例。以_ci(表示大小写不敏感),以_cs(表示大小写敏感),以_bin(表示用编码值进行比较)。

报错原因:两个不同的表使用了不同的collation。

解决办法:

using System

using System.Data

using System.Data.SqlClient

using System.Configuration

using System.Web

using System.Web.Security

using System.Web.UI

using System.Web.UI.HtmlControls

using System.Web.UI.WebControls

using System.Web.UI.WebControls.WebParts

using MySql.Data.MySqlClient

public class ntko_mysql_class

{

public ntko_mysql_class()

{

//

//TODO: 在此处添加构造函数逻辑

//

}

/// <summary>

/// 数据库联接字符串

/// </summary>

public MySqlConnection connstr//连接字符串

/// <summary>

///定义示例程序文档保存为其它格式文档路径

/// </summary>

public string demotitle, officepath, htmlpath, pdfpath, attachpath

/// <summary>

/// 获取数据库联接字符串

/// </summary>

public string getconnstr()

{

string constr

constr = System.Configuration.ConfigurationManager.AppSettings["mysql_dbconn"]

return constr

}

public void open() //打开数据库

{

string constr

constr = getconnstr()

connstr = new MySqlConnection(constr)

connstr.Open()

}

public void close() //关闭数据库

{

connstr.Dispose()

connstr.Close()

}

/// <summary>

/// 执行SQL语句

/// </summary>

/// <param name="sql">SQL语句</param>

public void execsql(string sql)

{

open()

MySqlCommand cmd = new MySqlCommand(sql, connstr)

cmd.ExecuteNonQuery()

close()

}

/// <summary>

/// 返回DataSet对象

/// </summary>

/// <param name="sql"></param>

/// <returns></returns>

public DataSet dataset(string sql)

{

open()

MySqlDataAdapter rs = new MySqlDataAdapter(sql, connstr)

DataSet ds = new DataSet()

rs.Fill(ds)

return ds

}

/// <summary>

/// 返回DataView对象

/// </summary>

/// <param name="sql"></param>

/// <returns></returns>

public DataView dataview(string sql)

{

DataSet ds = new DataSet()

ds = dataset(sql)

DataView dv = new DataView(ds.Tables[0])

return dv

}

/// <summary>

/// 返回DataReader对象

/// </summary>

/// <param name="sql"></param>

/// <returns></returns>

public MySqlDataReader datareader(string sql)

{

open()

MySqlCommand cmd = new MySqlCommand(sql, connstr)

MySqlDataReader dr = cmd.ExecuteReader()

return dr

}

/// <summary>

/// 获取示例程序标题

/// </summary>

/// <returns></returns>

public string getdemotitle()

{

demotitle = System.Configuration.ConfigurationManager.AppSettings["demotitle"]

return demotitle

}

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7190472.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-02
下一篇 2023-04-02

发表评论

登录后才能评论

评论列表(0条)

保存