C#访问MySQL(二):数据插入与修改(增改)

本文介绍了如何利用Chloe库在.NET环境中与MySQL数据库进行交互,包括创建数据库实体类、增加数据、更新数据的方法。通过示例展示了具体的代码实现,如创建Tb_A实体类,使用MySqlConnectionFactory封装数据库连接,并提供了插入新数据和修改已有数据的函数及其调用方式。

前言:
前面说了数据库的连接查询,现在说数据库的增删改。这里引入一个数据库的实体类,就是将当前数据库的某一个表里面所有字段写成实体类,如下:

1.数据库的实体类:

需要项目里下载Chloe.dll和Chloe.Mysql.dll,如下:在这里插入图片描述

例如有表如下:
在这里插入图片描述

它的实体类就是:



using System;
using Chloe.Entity;
using Chloe.Annotations;
namespace WpfApp1
{
    /// <summary>
    /// 实体类tb_a。(属性说明自动提取数据库字段的描述信息)
    /// </summary>
    [TableAttribute("tb_a")]
    [Serializable]
    public partial class Tb_A
    {
        #region Model
        private int _ID;
        private string _Name;
        private int? _Age;
        private int? _Sex;

        /// <summary>
        /// ID
        /// </summary>
        [ColumnAttribute(IsPrimaryKey = true)]
        public int ID
        {
            get { return _ID; }
            set
            {
                this._ID = value;
            }
        }
        /// <summary>
        /// 名字
        /// </summary>
        public string Name
        {
            get { return _Name; }
            set
            {
                this._Name = value;
            }
        }
        /// <summary>
        /// 年龄
        /// </summary>
        public int? Age
        {
            get { return _Age; }
            set
            {
                this._Age = value;
            }
        }
        /// <summary>
        /// 性别
        /// </summary>
        public int? Sex
        {
            get { return _Sex; }
            set
            {
                this._Sex = value;
            }
        }
        #endregion
    }
}

2.增加一行数据:

封装一下IDbConnectionFactory。

        public class MySqlConnectionFactory : IDbConnectionFactory
        {
            string _connString = null;
            public MySqlConnectionFactory(string connString)
            {
                this._connString = connString;
            }
            public IDbConnection CreateConnection()
            {
                IDbConnection conn = new MySqlConnection(this._connString);
                return conn;
            }
        }

插入一行数据方法:

        internal static bool InsertNewData(Tb_A Model, out long lID)
        {
            MySqlContext context = new MySqlContext(new MySqlConnectionFactory("host = 数据库IP; Port = 数据库端口; Database = 数据库名; uid = 数据库账户; pwd = 数据库密码; Charset = utf8; Allow User Variables = true"));
            using (MySqlContext dx = context)
            {
                IQuery<Tb_A> q = dx.Query<Tb_A>();
                lID = dx.Insert<Tb_A>(Model).ID;
                return true;
            }
        }

调用:

        private void Button_Click(object sender, RoutedEventArgs e)
        {
            Tb_A Model = new Tb_A()
            {
                Age = 18,
                Name = "张三",
                Sex = 1,
            };
            long ID = 0;
            InsertNewData(Model,out ID);
        }

结果:
在这里插入图片描述

3.修改某一行数据:

方法:

        internal static bool UpdateName(string name,long ID)
        {
            try
            {
                MySqlContext context = new MySqlContext(new MySqlConnectionFactory("host = 数据库IP; Port = 数据库端口; Database = 数据库名; uid = 数据库账户; pwd = 数据库密码; Charset = utf8; Allow User Variables = true"));
                using (MySqlContext dx = context)
                {
                    return dx.Update<Tb_A>(a => a.ID == ID, a => new Tb_A()
                    {
                        Name = name,

                    }) >= 0;
                }
            }
            catch (Exception)
            {
                return false;
            }
        }

调用:

        private void Button_Click(object sender, RoutedEventArgs e)
        {
            Tb_A Model = new Tb_A()
            {
                Age = 18,
                Name = "张三",
                Sex = 1,
            };
            long ID = 1;
            UpdateName("李四" , ID);
        }

结果:

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

LcVong

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值