一つのASP.NETのMYSQLのデータベース操作クラスが独自にカプセル化されている
2925 ワード
/**
* : MYSQL
*/
using System;
using System.Data;
using MySql.Data.MySqlClient;
namespace Niunan.BYLW.Utility
{
/// MYSQL
///
///
public class MYSQLHelper
{
private MySqlConnection conn = null;
private MySqlCommand cmd = null;
private MySqlDataReader sdr = null;
public MYSQLHelper()
{
//string connStr = WebConfigurationManager.ConnectionStrings["connStr"].ToString();
string connStr = "server=localhost;database=test;uid=root;pwd=123456;charset=utf8";
conn = new MySqlConnection(connStr);
}
/// Command
///
///
/// SQL
public void CreateCommand(string sql)
{
conn.Open();
cmd = new MySqlCommand(sql, conn);
}
///
///
///
///
///
public void AddParameter(string paramName, object value)
{
cmd.Parameters.Add(new MySqlParameter(paramName, value));
}
/// SQL
///
///
/// SQL
///
///
public bool ExecuteNonQuery()
{
int res;
try
{
res = cmd.ExecuteNonQuery();
if (res > 0)
{
return true;
}
}
catch (Exception ex)
{
throw ex;
}
finally
{
if (conn.State == ConnectionState.Open)
{
conn.Close();
}
}
return false;
}
/// SQL
///
///
/// SQL
///
public DataTable ExecuteQuery()
{
DataTable dt = new DataTable();
using (sdr = cmd.ExecuteReader(CommandBehavior.CloseConnection))
{
dt.Load(sdr);
}
return dt;
}
/// SQL
///
///
///
public string ExecuteScalar()
{
string res = "";
try
{
object obj = cmd.ExecuteScalar();
if (obj != null)
{
res = obj.ToString();
}
}
catch (Exception ex)
{
throw ex;
}
finally
{
if (conn.State == ConnectionState.Open)
{
conn.Close();
}
}
return res;
}
}
}
すべてそのSQLITEHelperの操作類を運んできたので、MySqlConnectionなどの変数名を変えて、MYSQLにとってよく中国語の文字化けして、実験を経て、解決方法:
①PHPMYADMINでMYSQLデータベースを作成するときはUTF-8のコードを選択してください
②上記のデータベース操作クラスの接続文字列にcharset=utf 8を付けておく
このように上の操作類で中国語を挿入すると文字化けしません.