.net core 3.1 mysql_.NetCore 3.1 MySqlHelper

public sealed classMySqlHelper

{public static readonly string connectionString = AppSettings.Configuration["ConnectionStrings:MySql"];#region ExecuteMySqlScript

public static int ExecuteMySqlScript(stringpath)

{using (MySqlConnection mySqlConnection = newMySqlConnection(connectionString))

{using (MySqlCommand mySqlCommand = newMySqlCommand())

{using (StreamReader streamReader = newStreamReader(path, System.Text.Encoding.UTF8))

{

mySqlCommand.Connection=mySqlConnection;

mySqlCommand.CommandText=streamReader.ReadToEnd();

mySqlConnection.Open();returnmySqlCommand.ExecuteNonQuery();

}

}

}

}#endregion ExecuteMySqlScript

#region ExecuteNonQuery

public static int ExecuteNonQuery(string commandText, paramsMySqlParameter[] commandParameters)

{using (MySqlConnection mySqlConnection = newMySqlConnection(connectionString))

{using (MySqlCommand mySqlCommand = newMySqlCommand(commandText, mySqlConnection))

{if (commandParameters != null)

{

mySqlCommand.Parameters.Clear();

mySqlCommand.Parameters.AddRange(commandParameters);

}

mySqlConnection.Open();returnmySqlCommand.ExecuteNonQuery();

}

}

}#endregion ExecuteNonQuery

#region GetEntities

public static List GetEntities(string commandText, paramsMySqlParameter[] commandParameters)

{using (MySqlConnection mySqlConnection = newMySqlConnection(connectionString))

{using (MySqlCommand mySqlCommand = newMySqlCommand(commandText, mySqlConnection))

{

mySqlConnection.Open();if (commandParameters != null)

{

mySqlCommand.Parameters.Clear();

mySqlCommand.Parameters.AddRange(commandParameters);

}using (MySqlDataReader dataReader =mySqlCommand.ExecuteReader())

{

List list = new List();while(dataReader.Read())

{

List field = new List(dataReader.FieldCount);for (int i = 0; i < dataReader.FieldCount; i++)

{

field.Add(dataReader.GetName(i).ToLower());

}

T model= Activator.CreateInstance();foreach (PropertyInfo property in model.GetType().GetProperties(BindingFlags.GetProperty | BindingFlags.Public |BindingFlags.Instance))

{if(field.Contains(property.Name.ToLower()))

{

property.SetValue(model, Convert.ChangeType(dataReader[property.Name], property.PropertyType),null);

}

}

list.Add(model);

}returnlist;

}

}

}

}#endregion GetEntities

#region GetEntity

public static T GetEntity(string commandText, paramsMySqlParameter[] commandParameters)

{using (MySqlConnection mySqlConnection = newMySqlConnection(connectionString))

{using (MySqlCommand mySqlCommand = newMySqlCommand(commandText, mySqlConnection))

{

mySqlConnection.Open();if (commandParameters != null)

{

mySqlCommand.Parameters.Clear();

mySqlCommand.Parameters.AddRange(commandParameters);

}using (MySqlDataReader dataReader =mySqlCommand.ExecuteReader())

{

T model= Activator.CreateInstance();if(dataReader.Read())

{

List field = new List(dataReader.FieldCount);for (int i = 0; i < dataReader.FieldCount; i++)

{

field.Add(dataReader.GetName(i).ToLower());

}foreach (PropertyInfo property in model.GetType().GetProperties(BindingFlags.GetProperty | BindingFlags.Public |BindingFlags.Instance))

{if(field.Contains(property.Name.ToLower()))

{

property.SetValue(model, Convert.ChangeType(dataReader[property.Name], property.PropertyType),null);

}

}

}returnmodel;

}

}

}

}#endregion GetEntity

#region ExecuteReader

public static MySqlDataReader ExecuteReader(string commandText, paramsMySqlParameter[] commandParameters)

{

MySqlConnection mySqlConnection= newMySqlConnection(connectionString);

MySqlCommand mySqlCommand= newMySqlCommand(commandText, mySqlConnection);if (commandParameters != null)

{

mySqlCommand.Parameters.Clear();

mySqlCommand.Parameters.AddRange(commandParameters);

}

mySqlConnection.Open();returnmySqlCommand.ExecuteReader(CommandBehavior.CloseConnection);

}#endregion ExecuteReader

#region ExecuteScalar

public static object ExecuteScalar(string commandText, paramsMySqlParameter[] commandParameters)

{using (MySqlConnection mySqlConnection = newMySqlConnection(connectionString))

{using (MySqlCommand mySqlCommand = newMySqlCommand(commandText, mySqlConnection))

{if (commandParameters != null)

{

mySqlCommand.Parameters.Clear();

mySqlCommand.Parameters.AddRange(commandParameters);

}

mySqlConnection.Open();returnmySqlCommand.ExecuteScalar();

}

}

}#endregion ExecuteScalar

#region ExecuteDataSet

public static DataSet ExecuteDataSet(string commandText, paramsMySqlParameter[] commandParameters)

{using (MySqlDataAdapter mySqlDataAdapter = newMySqlDataAdapter(commandText, connectionString))

{

DataSet dataSet= newDataSet();if (commandParameters != null)

{

mySqlDataAdapter.SelectCommand.Parameters.Clear();

mySqlDataAdapter.SelectCommand.Parameters.AddRange(commandParameters);

}

mySqlDataAdapter.Fill(dataSet);returndataSet;

}

}#endregion ExecuteDataSet

#region ExecuteDataTable

public static DataTable ExecuteDataTable(string commandText, paramsMySqlParameter[] commandParameters)

{using (MySqlDataAdapter mySqlDataAdapter = newMySqlDataAdapter(commandText, connectionString))

{

DataTable dataTable= newDataTable();if (commandParameters != null)

{

mySqlDataAdapter.SelectCommand.Parameters.Clear();

mySqlDataAdapter.SelectCommand.Parameters.AddRange(commandParameters);

}

mySqlDataAdapter.Fill(dataTable);returndataTable;

}

}#endregion ExecuteDataTable

#region ExecuteTransaction

public static int ExecuteTransaction(Listlist)

{using (MySqlConnection mySqlConnection = newMySqlConnection(connectionString))

{using (MySqlCommand mySqlCommand = newMySqlCommand())

{

mySqlConnection.Open();

MySqlTransaction mySqlTransaction=mySqlConnection.BeginTransaction();

mySqlCommand.Connection=mySqlConnection;

mySqlCommand.Transaction=mySqlTransaction;try{int result = 0;foreach (var item inlist)

{

mySqlCommand.CommandText=item;

result+=mySqlCommand.ExecuteNonQuery();

}

mySqlTransaction.Commit();returnresult;

}catch(System.Exception)

{

mySqlTransaction.Rollback();return 0;

}

}

}

}public static int ExecuteTransaction(List>list)

{using (MySqlConnection mySqlConnection = newMySqlConnection(connectionString))

{using (MySqlCommand mySqlCommand = newMySqlCommand())

{

mySqlConnection.Open();

MySqlTransaction mySqlTransaction=mySqlConnection.BeginTransaction();

mySqlCommand.Connection=mySqlConnection;

mySqlCommand.Transaction=mySqlTransaction;try{int result = 0;foreach (var item inlist)

{

mySqlCommand.CommandText=item.Key;

mySqlCommand.Parameters.Clear();

mySqlCommand.Parameters.AddRange(item.Value);

result+=mySqlCommand.ExecuteNonQuery();

}

mySqlTransaction.Commit();returnresult;

}catch(System.Exception)

{

mySqlTransaction.Rollback();return 0;

}

}

}

}#endregion ExecuteTransaction}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值