MySQL数据库专栏(四)MySQL数据库链接操作C#篇

news2024/12/23 14:09:59

摘要


        本篇文章主要介绍C#链接MySQL数据库的接口介绍,使用实例及注意事项,辅助类的封装及调用实例,可以直接移植到项目里面使用。

目录


1、添加引用
2、接口介绍
     2.1、MySqlConnection
     2.2、MySqlCommand
     2.3、MySqlDataReader
     2.4、MySqlDataAdapter
     2.5、MySqlTransaction
3、全网功能最全辅助类实现
4、辅助类调用实例

1、添加引用

IDE为Visual Studio 2022,选择工具->NuGet包管理器->管理解决方案的NuGet程序包

选择浏览,在输入框中输入MySql进行搜索,选中MySql.Data选项

版本选择和数据库安装版本最接近的,我这里选择8.0.33版本,然后点击安装,安装完成后引用自动添加完成。

2、接口介绍

访问数据库主要用到如下几个类,下面对其功能进行依次介绍

2.1、MySqlConnection

功能:建立数据库连接,通过MySqlConnection对象,可以建立与MySQL数据库的连接,以便执行SQL语句和访问数据。

常用方法和属性:

Open()用于打开连接

Close()用于关闭连接

State获取当前MySqlConnection对象数据库链接状态

使用实例

static void Main(string[] args)
{
    //链接MySql数据库相关的IP地址、数据库名称、用户名称、密码
    string connstr = "server=127.0.0.1;database=db_demo;username=root;password=luoboshou123";

    MySqlConnection conn = new MySqlConnection(connstr);

    //打开数据库
    if (conn.State != System.Data.ConnectionState.Open)
    {
        conn.Open();
    }

    //数据库其他操作

    //关闭数据库
    conn.Close();
}

2.2、MySqlCommand

MySqlCommand类是.NET Framework中用于与MySQL数据库交互的一个重要类,它属于MySql.Data.MySqlClient命名空间。这个类提供了一系列方法和属性,用于执行SQL语句、管理事务、处理参数化查询等。以下是对MySqlCommand类接口的详细说明:

MySqlCommand类的构造函数

MySqlCommand类提供了多个构造函数,允许用户以不同的方式创建MySqlCommand对象。常用的构造函数包括:

接受一个SQL语句字符串和一个MySqlConnection对象作为参数的构造函数。

仅接受一个SQL语句字符串作为参数的构造函数(但通常需要在后续操作中设置Connection属性以指定数据库连接)。

主要方法和属性

CommandText属性:获取或设置要执行的SQL语句或存储过程的名称。

Connection属性:获取或设置与MySQL数据库的连接。

CommandType属性:获取或设置CommandText属性的类型(如Text、StoredProcedure等)。

Parameters属性:获取表示参数集合的MySqlParameterCollection对象,用于参数化查询。

ExecuteNonQuery方法:执行诸如INSERT、UPDATE、DELETE等非查询SQL语句,并返回受影响的行数。

ExecuteReader方法:执行诸如SELECT等查询SQL语句,并返回一个MySqlDataReader对象,用于读取查询结果。

ExecuteScalar方法:执行查询,并返回查询结果中的第一行第一列的值。如果查询结果为空,则返回null。

2.3、MySqlDataReader

MySqlDataReader是.NET Framework中用于从MySQL数据库中读取数据的一个快速、高效的类。以下是对MySqlDataReader接口的详细说明:

基本功能

MySqlDataReader允许你从MySQL数据库中读取数据行,并且以只读、向前只进的方式访问数据集中的每一行。它提供了一种从数据库中检索数据的高效方法,特别是在处理大量数据时。

使用方法

创建数据库连接:首先,你需要创建一个MySqlConnection对象,并使用适当的连接字符串打开与MySQL数据库的连接。

执行SQL查询:然后,创建一个MySqlCommand对象,将你的SQL查询语句传递给该对象,并指定要使用的MySqlConnection对象。

读取数据:接下来,使用MySqlCommand对象的ExecuteReader方法执行查询,并返回一个MySqlDataReader对象。你可以通过调用MySqlDataReader对象的Read方法逐行读取数据。

使用实例

static void Main(string[] args)
{
    //链接MySql数据库相关的IP地址、数据库名称、用户名称、密码
    string connstr = "server=127.0.0.1;database=db_demo;username=root;password=luoboshou123";

    MySqlConnection conn = new MySqlConnection(connstr);
    //打开数据库
    if (conn.State != System.Data.ConnectionState.Open)
    {
        conn.Open();
    }

    //数据库其他操作
    MySqlCommand cmd = new MySqlCommand();
    cmd.CommandType = CommandType.Text;//设置执行SQL语句
            
    cmd.Connection = conn;//数据库链接

    string strSql;
    //插入一条数据
    strSql = "insert into t_user (user_name,password,nick_name,user_no,status,phone) values('张三6','12345678','红太阳','131024685941523145',0,'13465231586')";
    cmd.CommandText = strSql;//执行的SQL语句
    cmd.ExecuteNonQuery();

    //修改一条数据
    strSql = "update t_user set nick_name = '王麻子' where id = 1";
    cmd.CommandText = strSql;//执行的SQL语句
    cmd.ExecuteNonQuery();

    //删除一条数据
    strSql = "delete from t_user where id = 11";
    cmd.CommandText = strSql;//执行的SQL语句
    cmd.ExecuteNonQuery();

    //执行查询,并返回查询结果中的第一行第一列的值
    strSql = "select count(*) from t_user";
    cmd.CommandText = strSql;//执行的SQL语句
    Object resutl = cmd.ExecuteScalar();
    Console.WriteLine(resutl.ToString());

    //查看所有数据
    strSql = "select * from t_user";
    cmd.CommandText = strSql;
    MySqlDataReader reader = cmd.ExecuteReader();

    for (int i = 0; i < reader.FieldCount; i++)
    {
        string name = reader.GetName(i);//获取字段名称
        Console.Write(name);
        if(i != reader.FieldCount - 1)
        {
            Console.Write(" | ");
        }
        else
        {
            Console.Write("\r\n");
        }
    }
            
    while (reader.Read())//循环读取每一行数据
    {
        Console.Write(reader["id"].ToString());
        Console.Write(" | ");
        Console.Write(reader["user_name"].ToString());
        Console.Write(" | ");
        Console.Write(reader["password"].ToString());
        Console.Write(" | ");
        Console.Write(reader["nick_name"].ToString());
        Console.Write(" | ");
        Console.Write(reader["user_no"].ToString());
        Console.Write(" | ");
        Console.Write(reader["status"].ToString());
        Console.Write(" | ");
        Console.Write(reader["phone"].ToString());
        Console.Write("\r\n");
    }

    reader.Close();
    //关闭数据库
    conn.Close();
    Console.ReadKey();
}

2.4、MySqlDataAdapter

MySqlDataAdapter类是ADO.NET提供的一个用于与MySQL数据库进行交互的重要类,它充当DataSet和MySQL数据库之间的桥梁,用于检索和保存数据。以下是对MySqlDataAdapter类的详细说明:

主要功能

数据检索:MySqlDataAdapter通过Fill方法从MySQL数据库中检索数据,并将数据填充到DataSet或DataTable对象中。这允许开发人员在内存中存储和操作数据库数据。

数据更新:除了检索数据外,MySqlDataAdapter还可以通过Update方法将DataSet或DataTable对象中的更改保存回MySQL数据库。这实现了数据的双向同步。

命令管理:MySqlDataAdapter包含SelectCommand、InsertCommand、DeleteCommand和UpdateCommand等属性,这些属性允许开发人员指定用于执行相应数据库操作的SQL命令。

使用方法

创建连接:首先,需要创建一个MySqlConnection对象来打开与MySQL数据库的连接。

创建命令:然后,创建一个MySqlCommand对象,并设置其CommandText属性为要执行的SQL语句。此外,还可以根据需要设置其他属性,如CommandType和Parameters等。

创建适配器:接下来,创建一个MySqlDataAdapter对象,并将之前创建的MySqlCommand对象传递给它。这样,MySqlDataAdapter就知道要执行哪个SQL语句来检索或更新数据。

执行操作

要检索数据,调用MySqlDataAdapter的Fill方法,并将DataSet或DataTable对象作为参数传递给它。Fill方法将执行SQL语句,并将结果填充到指定的DataSet或DataTable对象中。

要更新数据,首先修改DataSet或DataTable对象中的数据,然后调用MySqlDataAdapter的Update方法。Update方法将使用适当的SQL语句(如INSERT、UPDATE或DELETE)将更改保存回MySQL数据库。

重要属性

SelectCommand:获取或设置用于从数据库中选择数据的SQL命令对象。

InsertCommand:获取或设置用于向数据库中插入数据的SQL命令对象。

UpdateCommand:获取或设置用于更新数据库中数据的SQL命令对象。

DeleteCommand:获取或设置用于从数据库中删除数据的SQL命令对象。

TableMappings:获取或设置用于简化数据的加载和更新操作的表映射信息。

注意事项

资源管理:由于MySqlDataAdapter使用了非托管资源,因此在使用完毕后应确保正确释放资源。通常,可以使用using语句来自动管理MySqlDataAdapter对象的生命周期。

异常处理:在执行数据库操作时,应始终考虑异常处理。可以使用try-catch块来捕获和处理可能发生的异常,如连接失败、查询错误等。

性能优化:在处理大量数据时,应注意性能优化。例如,可以使用参数化查询来提高查询效率和安全性;可以通过设置适当的命令超时时间来避免长时间等待数据库响应等

使用实例

static void Main(string[] args)
{
    //链接MySql数据库相关的IP地址、数据库名称、用户名称、密码
    string connstr = "server=127.0.0.1;database=db_demo;username=root;password=luoboshou123";

    MySqlConnection conn = new MySqlConnection(connstr);
    //打开数据库
    if (conn.State != System.Data.ConnectionState.Open)
    {
        conn.Open();
    }

    //数据库其他操作
    MySqlCommand cmd = new MySqlCommand();
    cmd.CommandType = CommandType.Text;//设置执行SQL语句

    cmd.Connection = conn;//数据库链接

    //查看所有数据
    string strSql = "select * from t_user";
    cmd.CommandText = strSql;
    DataTable table = new DataTable();
    MySqlDataAdapter adapter = new MySqlDataAdapter(cmd);
    adapter.Fill(table);

    if (table.Rows.Count > 0)
    {
        //打印所有列名
        string columnName = string.Empty;
        for (int i = 0; i < table.Columns.Count; i++)
        {
            columnName += table.Columns[i].ColumnName + " | ";
        }
        Console.WriteLine(columnName);
        Console.WriteLine("-------------------------");

        //打印每一行的数据
        foreach (DataRow row in table.Rows)
        {
            string columnStr = string.Empty;
            foreach (DataColumn column in table.Columns)
            {
                columnStr += row[column] + " | ";
            }
            Console.WriteLine(columnStr);
        }
    }

    //关闭数据库
    conn.Close();
    Console.ReadKey();
}

2.5、MySqlTransaction

MySqlTransaction类是ADO.NET中用于在MySQL数据库上执行事务操作的类。事务是一组要么全都成功要么全都失败的数据库操作序列,它确保了数据的一致性和完整性。以下是对MySqlTransaction类接口的详细说明:

主要功能和用途

MySqlTransaction类主要用于在MySQL数据库上开始、提交和回滚事务。它提供了对事务边界的控制,确保了一组数据库操作要么全部成功,要么在遇到错误时全部回滚,从而保持数据的一致性和完整性。

重要方法和属性

BeginTransaction方法

功能:开始一个数据库事务。

返回值:返回一个MySqlTransaction对象,表示新开始的事务。

注意事项:在开始事务之前,必须确保已经建立了与MySQL数据库的连接,并且该连接是打开的。

Commit方法

功能:提交当前事务中的所有更改,并将它们永久保存到数据库中。

返回值:无。

注意事项:在调用Commit方法之前,必须确保所有的数据库操作都已经成功完成,并且没有发生任何错误。

Rollback方法

功能:回滚当前事务中的所有更改,撤销自事务开始以来所做的所有操作。

返回值:无。

注意事项:在发生错误或需要取消事务时,应调用Rollback方法来撤销所做的更改。

IsolationLevel属性

功能:获取或设置当前事务的隔离级别。

隔离级别选项:包括读未提交(ReadUncommitted)、读已提交(ReadCommitted)、可重复读(RepeatableRead)和可串行化(Serializable)等。

注意事项:隔离级别决定了事务之间的可见性和并发性。选择合适的隔离级别对于确保数据的一致性和优化性能至关重

使用步骤和示例

建立数据库连接:首先,需要创建一个MySqlConnection对象来打开与MySQL数据库的连接。

开始事务:通过调用BeginTransaction方法来开始一个新的事务。这将返回一个MySqlTransaction对象,用于表示该事务。

执行数据库操作:在事务的上下文中执行所需的数据库操作。这些操作可以是插入、更新、删除等。

提交或回滚事务:根据操作的结果,决定是调用Commit方法来提交事务,还是调用Rollback方法来回滚事务。

以下是一个使用MySqlTransaction类的示例代码:

static void Main(string[] args)
{
    //链接MySql数据库相关的IP地址、数据库名称、用户名称、密码
    string connstr = "server=127.0.0.1;database=db_demo;username=root;password=luoboshou123";

    MySqlConnection conn = new MySqlConnection(connstr);
    //打开数据库
    if (conn.State != System.Data.ConnectionState.Open)
    {
        conn.Open();
    }

    //数据库其他操作
    MySqlCommand cmd = new MySqlCommand();
    cmd.CommandType = CommandType.Text;//设置执行SQL语句
    cmd.Connection = conn;//数据库链接
    cmd.Transaction = conn.BeginTransaction();

    //插入一条数据
    string strSql = "insert into t_user (user_name,password,nick_name,user_no,status,phone) values('张三6','12345678','红太阳','131024685941523145',0,'13465231586')";
    cmd.CommandText = strSql;//执行的SQL语句
    cmd.ExecuteNonQuery();

    cmd.Transaction.Commit();
    //cmd.Transaction.Rollback();

    //查看所有数据
    strSql = "select * from t_user";
    cmd.CommandText = strSql;
    MySqlDataReader reader = cmd.ExecuteReader();

    for (int i = 0; i < reader.FieldCount; i++)
    {
        string name = reader.GetName(i);//获取字段名称
        Console.Write(name);
        if (i != reader.FieldCount - 1)
        {
            Console.Write(" | ");
        }
        else
        {
            Console.Write("\r\n");
        }
    }

    while (reader.Read())//循环读取每一行数据
    {
        Console.Write(reader["id"].ToString());
        Console.Write(" | ");
        Console.Write(reader["user_name"].ToString());
        Console.Write(" | ");
        Console.Write(reader["password"].ToString());
        Console.Write(" | ");
        Console.Write(reader["nick_name"].ToString());
        Console.Write(" | ");
        Console.Write(reader["user_no"].ToString());
        Console.Write(" | ");
        Console.Write(reader["status"].ToString());
        Console.Write(" | ");
        Console.Write(reader["phone"].ToString());
        Console.Write("\r\n");
    }

    reader.Close();
    //关闭数据库
    conn.Close();
    Console.ReadKey();
}

3、全网功能最全辅助类实现 

using System;
using System.Collections.Generic;
using MySql.Data.MySqlClient;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data;

namespace MySQLTestDemo
{
    public class MySqlHelper
    {
        #region 私有
        /// <summary>
        /// 数据库链接字符串
        /// </summary>
        private static readonly string strConn = "server=127.0.0.1;database=db_demo;username=root;password=luoboshou123";

        /// <summary>
        /// 数据库链接类
        /// </summary>
        private MySqlConnection conn = null;

        /// <summary>
        /// 数据库指令执行类
        /// </summary>
        private MySqlCommand cmd = null;
        #endregion

        /// <summary>
        /// 指令执行类
        /// </summary>
        public MySqlCommand Cmd
        {
            get 
            { 
                return cmd;
            }
        }

        /// <summary>
        /// 外部调用简化接口
        /// </summary>
        /// <returns></returns>
        public static MySqlHelper NewMySql
        {
            get
            {
                return new MySqlHelper();
            }
        }

        /// <summary>
        /// 初始化Mysql
        /// </summary>
        public void Init(string strSql = "", CommandType commandType = CommandType.Text)
        {
            Close();
            if (conn == null)
            {
                conn = new MySqlConnection(strConn);
            }
            if (cmd == null)
            {
                cmd = new MySqlCommand();
                cmd.Connection = conn;
                cmd.CommandType = commandType;
            }
            if (strSql != "")
            {
                cmd.CommandText = strSql;
            }

        }

        /// <summary>
        /// 关闭MySql
        /// </summary>
        public void Close()
        {
            if (cmd != null)
            {
                if (cmd.Transaction != null)
                {
                    cmd.Transaction = null;
                }
                cmd.Dispose();
                cmd = null;
            }
            if (conn != null)
            {
                conn.Close();
                conn = null;
            }
        }

        /// <summary>
        /// 执行增、删、改操作
        /// </summary>
        /// <param name="strSql"></param>
        /// <returns></returns>
        public int ExecuteNonSql(string strSql, ref string errMsg, MySqlParameter[] param = null)
        {
            Init(strSql);
            try
            {
                conn.Open();
                if (param != null)
                {
                    cmd.Parameters.AddRange(param);
                }
                return cmd.ExecuteNonQuery();
            }
            catch (Exception ex)
            {
                //将错误信息写入日志文件
                errMsg = "执行ExecuteNonSql方法时发生错误,具体信息:" + ex.Message;
                return -1;
            }
            finally
            {
                Close();
            }
        }

        /// <summary>
        /// 执行单一结果的查询
        /// </summary>
        /// <param name="strSql"></param>
        /// <returns></returns>
        public object ExecuteSingleResult(string strSql, ref string errMsg, MySqlParameter[] param = null)
        {
            Init(strSql);
            try
            {
                conn.Open();
                if (param != null)
                {
                    cmd.Parameters.AddRange(param);
                }
                return cmd.ExecuteScalar();
            }
            catch (Exception ex)
            {
                //将错误信息写入日志文件
                errMsg = "执行GetSingleResult方法时发生错误,具体信息:" + ex.Message;
                return null;
            }
            finally
            {
                Close();
            }
        }

        /// <summary>
        /// 执行结果集的查询
        /// </summary>
        /// <param name="strSql"></param>
        /// <returns></returns>
        public MySqlDataReader ExecuteReader(string strSql, ref string errMsg, MySqlParameter[] param = null)
        {
            Init(strSql);
            try
            {
                conn.Open();
                if (param != null)
                {
                    cmd.Parameters.AddRange(param);
                }
                return cmd.ExecuteReader(CommandBehavior.CloseConnection);
            }
            catch (Exception ex)
            {
                //将错误信息写入日志文件
                errMsg = "执行GetReader(string sql)时发生错误,具体信息:" + ex.Message;
                return null;
            }
        }

        /// <summary>
        /// 执行数据集返回DataTable
        /// </summary>
        /// <param name="strSql"></param>
        /// <returns></returns>
        public DataTable ExecuteDataTable(string strSql, ref string errMsg)
        {
            Init(strSql);
            MySqlDataAdapter da = new MySqlDataAdapter(cmd);
            DataTable dt = new DataTable();
            try
            {
                conn.Open();
                da.Fill(dt);
                return dt;
            }
            catch (Exception ex)
            {
                //将错误信息写入日志文件
                errMsg = "执行GetDataSet(string sql)时发生错误,具体信息:" + ex.Message;
                return null;
            }
            finally
            {
                Close();
            }
        }

        #region 事务

        /// <summary>
        /// 开启事务
        /// </summary>
        /// <returns></returns>
        public bool BeginTransaction(ref string errMsg)
        {
            try
            {
                if (conn.State != ConnectionState.Open)
                {
                    conn.Open();
                }
                cmd.Transaction = conn.BeginTransaction();
                return true;
            }
            catch (Exception ex)
            {
                //将错误信息写入日志文件
                errMsg = "执行BeginTransaction方法时发生错误,具体信息:" + ex.Message;
                return false;
            }
        }

        /// <summary>
        /// 提交事务
        /// </summary>
        /// <returns></returns>
        public bool CommitTransaction(ref string errMsg)
        {
            try
            {
                cmd.Transaction.Commit();//提交事务(同时自动清除事务)
                return true;
            }
            catch (Exception ex)
            {
                //将错误信息写入日志文件
                errMsg = "执行CommitTransaction方法时发生错误,具体信息:" + ex.Message;
                return false;
            }
        }

        /// <summary>
        /// 回滚事务
        /// </summary>
        /// <returns></returns>
        public bool RollbackTransaction(ref string errMsg)
        {
            try
            {
                cmd.Transaction.Rollback();
                return true;
            }
            catch (Exception ex)
            {
                //将错误信息写入日志文件
                errMsg = "执行RollbackTransaction方法时发生错误,具体信息:" + ex.Message;
                return false;
            }
            
        }

        #endregion
    }//class
}//namespace

4、辅助类调用实例

using MySql.Data.MySqlClient;
using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace MySQLTestDemo
{
    internal class Program
    {
        static void Main(string[] args)
        {
            //执行增删改操作
            {
                Console.WriteLine("----------------执行增删改操作---------------------");
                string strSql = "update t_user set nick_name = '王麻子1' where id = 1";
                string errMsg = string.Empty;
                int flag = MySqlHelper.NewMySql.ExecuteNonSql(strSql, ref errMsg);
                Console.WriteLine(flag);
                if (flag == -1)
                {
                    Console.WriteLine(errMsg);
                }
            }
            

            //执行单一结果操作
            {
                Console.WriteLine("-----------------执行单一结果操作--------------------");
                string strSql = "select count(*) from t_user";
                string errMsg = string.Empty;
                object obj = MySqlHelper.NewMySql.ExecuteSingleResult(strSql, ref errMsg);
                Console.WriteLine(obj);
                if(obj == null)
                {
                    Console.WriteLine(errMsg);
                }
            }

            //执行结果集操作
            {
                Console.WriteLine("----------------执行结果集操作---------------------");
                string strSql = "select * from t_user";
                string errMsg = string.Empty;
                MySqlHelper mySqlHelper = new MySqlHelper();
                MySqlDataReader reader = mySqlHelper.ExecuteReader(strSql, ref errMsg);
                if (reader == null)
                {
                    Console.WriteLine(errMsg);
                }
                for (int i = 0; i < reader.FieldCount; i++)
                {
                    string name = reader.GetName(i);//获取字段名称
                    Console.Write(name);
                    if (i != reader.FieldCount - 1)
                    {
                        Console.Write(" | ");
                    }
                    else
                    {
                        Console.Write("\r\n");
                    }
                }

                while (reader.Read())//循环读取每一行数据
                {
                    Console.Write(reader["id"].ToString());
                    Console.Write(" | ");
                    Console.Write(reader["user_name"].ToString());
                    Console.Write(" | ");
                    Console.Write(reader["password"].ToString());
                    Console.Write(" | ");
                    Console.Write(reader["nick_name"].ToString());
                    Console.Write(" | ");
                    Console.Write(reader["user_no"].ToString());
                    Console.Write(" | ");
                    Console.Write(reader["status"].ToString());
                    Console.Write(" | ");
                    Console.Write(reader["phone"].ToString());
                    Console.Write("\r\n");
                }
                reader.Close();
                mySqlHelper.Close();
            }

            //执行DataTable结果集操作
            {
                Console.WriteLine("----------------执行DataTable结果集操作---------------------");
                string strSql = "select * from t_user";
                string errMsg = string.Empty;
                MySqlHelper mySqlHelper = new MySqlHelper();
                DataTable table = mySqlHelper.ExecuteDataTable(strSql, ref errMsg);
                if (table.Rows.Count > 0)
                {
                    //打印所有列名
                    string columnName = string.Empty;
                    for (int i = 0; i < table.Columns.Count; i++)
                    {
                        columnName += table.Columns[i].ColumnName + " | ";
                    }
                    Console.WriteLine(columnName);
                    Console.WriteLine("-------------------------");

                    //打印每一行的数据
                    foreach (DataRow row in table.Rows)
                    {
                        string columnStr = string.Empty;
                        foreach (DataColumn column in table.Columns)
                        {
                            columnStr += row[column] + " | ";
                        }
                        Console.WriteLine(columnStr);
                    }
                }
                mySqlHelper.Close();
            }

            //执行事务操作
            {
                Console.WriteLine("----------------执行事务操作---------------------");
                MySqlHelper mySqlHelper = new MySqlHelper();
                string errMsg = "";
                try
                {
                    mySqlHelper.Init();
                    if(!mySqlHelper.BeginTransaction(ref errMsg))
                    {
                        Console.WriteLine(errMsg);
                    }
                    string strSql = "update t_user set nick_name = '王麻子3' where id = 1";
                    mySqlHelper.Cmd.CommandText = strSql;
                    mySqlHelper.Cmd.ExecuteNonQuery();
                    if (!mySqlHelper.CommitTransaction(ref errMsg))
                    {
                        Console.WriteLine(errMsg);
                    }
                    //if (!mySqlHelper.RollbackTransaction(ref errMsg))
                    //{
                    //    Console.WriteLine(errMsg);
                    //}
                    Console.WriteLine("执行成功");
                }
                catch (Exception ex)
                {
                    if (!mySqlHelper.RollbackTransaction(ref errMsg))
                    {
                        Console.WriteLine(errMsg);
                    }
                    Console.WriteLine(ex.Message);
                }
                mySqlHelper.Close();
            }

            Console.ReadKey();
        }
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2239704.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

借助 Pause 容器调试 Pod

借助 Pause 容器调试 Pod 在 K8S 中&#xff0c;Pod 是最核心、最基础的资源对象&#xff0c;也是 Kubernetes 中调度最小单元。在介绍 Pause 容器之前需要先说明下 Pod 与容器的关系来理解为什么需要 Pause 容器来帮助调试 1. Pod 与 容器的关系 Pod 是一个抽象的逻辑概念&…

UE5 umg学习(四) 将UI控件切换到关卡中

视频资料 7、将UI控件渲染到关卡_哔哩哔哩_bilibili 在前三节里&#xff0c;创建了用户的控件蓝图Widget_BP 目标是运行的时候&#xff0c;开始运行这个蓝图&#xff0c;因此需要在开始事件触发运行 首先&#xff0c;回到主页&#xff0c;点击关卡蓝图 要从事件开始运行时 …

React Hooks在现代前端开发中的应用

&#x1f493; 博客主页&#xff1a;瑕疵的CSDN主页 &#x1f4dd; Gitee主页&#xff1a;瑕疵的gitee主页 ⏩ 文章专栏&#xff1a;《热点资讯》 React Hooks在现代前端开发中的应用 React Hooks在现代前端开发中的应用 React Hooks在现代前端开发中的应用 引言 React Hooks …

军工行业运维:监控易引领自主可控新潮流

在军工行业&#xff0c;信息安全和技术创新始终是发展的重中之重。随着信息化建设的不断深入&#xff0c;对监控产品的要求也日益严格。 监控易作为一款高性能、全面性的运维监控解决方案&#xff0c;凭借其国产化、自主可控的特性&#xff0c;以及对军工行业特殊需求的深刻理解…

【操作系统】——调度算法

&#x1f339;&#x1f60a;&#x1f339;博客主页&#xff1a;【Hello_shuoCSDN博客】 ✨操作系统详见 【操作系统专项】 ✨C语言知识详见&#xff1a;【C语言专项】 目录 先来先服务&#xff08;FCFS, First Come First Serve) 短作业优先&#xff08;SJF, Shortest Job Fi…

C++入门基础知识147—【关于C++ 一元运算符重载】

成长路上不孤单&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a; 【14后&#x1f60a;///C爱好者&#x1f60a;///持续分享所学&#x1f60a;///如有需要欢迎收藏转发///&#x1f60a;】 今日分享关于C 一元运算符重载的相关内容&#xff0…

【测试框架篇】单元测试框架pytest(1):环境安装和配置

一、pytest简介 Pytest是Python的一种单元测试框架&#xff0c;与Python自带的unittest测试框架类似&#xff0c;但是比 unittest框架使用起来更简洁&#xff0c;效率更高。 二、pytest特点 Pytest是一个非常成熟的Python测试框架,主要特点有以下几点&#xff1a; 非常容易…

【CANOE】【学习】【DecodeString】字节转为中文字符输出

系列文章目录 文章目录 系列文章目录前言一、DecodeString 转为中文字节输出二、代码举例1.代码Demo2.DecodeString 函数说明函数语法&#xff1a;参数说明&#xff1a;返回值&#xff1a;使用示例&#xff1a;示例代码&#xff1a; 说明&#xff1a; 前言 有时候使用的时候&a…

边缘计算在智能交通系统中的应用

&#x1f493; 博客主页&#xff1a;瑕疵的CSDN主页 &#x1f4dd; Gitee主页&#xff1a;瑕疵的gitee主页 ⏩ 文章专栏&#xff1a;《热点资讯》 边缘计算在智能交通系统中的应用 边缘计算在智能交通系统中的应用 边缘计算在智能交通系统中的应用 引言 边缘计算概述 定义与原…

CC1链学习记录

&#x1f338; 前言 上篇文章学习记录了URLDNS链&#xff0c;接下来学习一下Common-Colections利用链。 &#x1f338; 相关介绍 Common-Colections是Apache软件基金会的项目&#xff0c;对Java标准的Collections API提供了很好的补充&#xff0c;在其基础上对常用的数据结构…

边缘计算在智能物流中的应用

&#x1f493; 博客主页&#xff1a;瑕疵的CSDN主页 &#x1f4dd; Gitee主页&#xff1a;瑕疵的gitee主页 ⏩ 文章专栏&#xff1a;《热点资讯》 边缘计算在智能物流中的应用 边缘计算在智能物流中的应用 边缘计算在智能物流中的应用 引言 边缘计算概述 定义与原理 发展历程 …

《多模稳控应急通讯设备技术规范》出炉,应急通讯有章可循!

近日&#xff0c;由深圳市遨游通讯设备有限公司参与的《多模稳控应急通讯设备技术规范》在经历多项严格的审核程序后&#xff0c;由中国中小商会企业协会正式发布实施。该标准详细规定了多模稳控应急通讯设备的术语和定义、产品型号、技术要求、试验方法、检验规则、标志、包装…

生成任意3D和4D场景!GenXD:通用3D-4D联合生成框架 | 新加坡国立微软

文章链接: https://arxiv.org/pdf/2411.02319 项目链接&#xff1a;https://gen-x-d.github.io/ 有视频 亮点直击 设计了一个数据整理流程&#xff0c;从视频中获取包含可移动物体的高质量4D数据&#xff0c;并为30,000个视频标注了相机姿态。这个大规模数据集称为CamVid-30K&…

全面解读:低代码开发平台的必备要素——系统策划篇

在传统开发过程中&#xff0c;系统策划起着举足轻重的作用&#xff0c;它宛如一位幕后的总指挥&#xff0c;把控着整个软件开发项目的走向。而随着技术的不断进步&#xff0c;低代码开发平台逐渐崭露头角&#xff0c;它以快速开发、降低技术门槛等优势吸引了众多企业和开发者的…

如何通过工单池与抢单机制提升企业服务效率与客户满意度?

在许多企业的售后服务或维修管理中&#xff0c;工单管理常常是一个瓶颈。工单处理不及时、任务分配不合理&#xff0c;或者客户的需求没有被准确跟踪&#xff0c;都可能影响到服务质量&#xff0c;进而影响客户满意度。随着企业规模扩大&#xff0c;如何高效管理工单池、合理调…

智慧电厂新纪元:基于亿信ABI的电厂环保指挥管控平台实践

​在当今全球能源转型与环境保护的双重驱动下&#xff0c;电力行业正加速向智能化、绿色化迈进。本案例聚焦于某电厂的智能化转型实践&#xff0c;通过引入先进的烟气达标监测技术与碳资产管理平台&#xff0c;不仅实现了对电厂排放的精准控制&#xff0c;还极大提升了碳数据的…

【C++练习】计算并输出1到10的所有整数的阶乘之和

题目&#xff1a; 计算并输出1到10的所有整数的阶乘之和 描述 编写一个C程序&#xff0c;定义一个函数来计算给定整数n的阶乘&#xff0c;然后在main函数中利用该函数计算从1到10&#xff08;包括1和10&#xff09;所有整数的阶乘&#xff0c;并将这些阶乘值累加起来&#x…

51c嵌入式~单片机合集2

我自己的原文哦~ https://blog.51cto.com/whaosoft/12362395 一、不同的电平信号的MCU怎么通信&#xff1f; 下面这个“电平转换”电路&#xff0c;理解后令人心情愉快。电路设计其实也可以很有趣。 先说一说这个电路的用途&#xff1a;当两个MCU在不同的工作电压下工作&…

ROM修改进阶教程------安卓14 安卓15去除app签名验证的几种操作步骤 详细图文解析

在安卓14 安卓15的固件中。如果修改了系统级别的app。那么就会触发安卓14 15的应用签名验证。要么会导致修改的固件会进不去系统,或者进入系统有bug。博文将从几方面来解析去除安卓14 15应用签名验证的几种方法。 💝💝💝通过博文了解: 1💝💝💝-----安卓14去除…

抓包工具WireShark使用记录

目录 网卡选择&#xff1a; 抓包流程&#xff1a; 捕获过滤器 常用捕获过滤器&#xff1a; 抓包数据的显示 显示过滤器&#xff1a; 常用的显示过滤器&#xff1a; 实际工作中&#xff0c;在平台对接&#xff0c;设备对接等常常需要调试接口&#xff0c;PostMan虽然可以进…