三、手写ORM实现数据库更新

简介: 三、手写ORM实现数据库更新

在更新时,不需要更新所有字段,因此要排除主键

有些实体类字段或者表名与数据库字段不相符 解决办法:特性标记

 

public static class Extend
    {
        public static string GetMapping<T>(this T t) where T : MemberInfo  //继承属性和类共同的父类
        {
            if (t.IsDefined(typeof(BsAttributes), true))//如果找到BsAttributes,获取名称
            {
                BsAttributes bs = (BsAttributes)t.GetCustomAttribute(typeof(BsAttributes), true);
                return bs.Getname();
            }
            else
            {
                return t.Name;
            }
        }
    }


标记属性的特性类

[AttributeUsage(AttributeTargets.Property)]  //属性
 public class KeysAuthAtturbute : BsAttributes
 {
     public KeysAuthAtturbute(string name) : base(name)
     {
     }
 }

标记类名的特性类

[AttributeUsage(AttributeTargets.Class)]  //类
    public class TableAtturbute : BsAttributes
    {
        public TableAtturbute(string name):base(name)
        {
        }
    }


都继承BsAttributes 类

public class BsAttributes : Attribute
    {
        private string _name = null;
        public BsAttributes(string name)
        {
            this._name = name;
        }
        public  virtual string Getname()
        {
            return this._name;
        }
    }


 

编写完成只需要在实体类标记·

7052da144fc51c7aae8c0981f22c0df3_1483.png

 

贴上代码

public bool  Update<T>(T t)
      {
          Type type = typeof(T);
          //PropertyInfoKeys 是自己写的排除主键的方法
          string columString = string.Join(",", type.PropertyInfoKeys().Select(p => $"[{p.Name}]=@{p.Name}"));
          IEnumerable<SqlParameter> parameters = type.PropertyInfoKeys().Select(p =>
          new SqlParameter($"@{p.GetMapping}", p.GetValue(t) ?? DBNull.Value));
          string sql = $"update [{type.Name}] set {columString}  where ID=@ID";
          if (conn.State == System.Data.ConnectionState.Closed)
          {
              conn.Open();
          }
          SqlCommand cmd = new SqlCommand(sql, conn);
          cmd.Parameters.AddRange(parameters.ToArray());
          int result = cmd.ExecuteNonQuery();
          return result==1;
      }


相关文章
|
6月前
|
SQL 关系型数据库 MySQL
探索Gorm - Golang流行的数据库ORM框架
探索Gorm - Golang流行的数据库ORM框架
|
2月前
|
关系型数据库 MySQL 数据库
ORM对mysql数据库中数据进行操作报错解决
ORM对mysql数据库中数据进行操作报错解决
85 2
|
3月前
|
SQL 开发框架 数据库
".NET开发者的超能力:AgileEAS.NET ORM带你穿越数据库的迷宫,让数据操作变得轻松又神奇!"
【8月更文挑战第16天】AgileEAS.NET是面向.NET平台的企业应用开发框架,核心功能包括数据关系映射(ORM),允许以面向对象方式操作数据库,无需编写复杂SQL。通过继承`AgileEAS.Data.Entity`创建实体类对应数据库表,利用ORM简化数据访问层编码。支持基本的CRUD操作及复杂查询如条件筛选、排序和分页,并可通过导航属性实现多表关联。此外,提供了事务管理功能确保数据一致性。AgileEAS.NET的ORM简化了数据库操作,提升了开发效率和代码可维护性。
53 5
|
2月前
|
存储 关系型数据库 MySQL
【阿里规约】阿里开发手册解读——数据库和ORM篇
从命名规范、建表规范、查询规范、索引规范、操作规范等角度出发,详细阐述MySQL数据库使用过程中所需要遵循的各种规范。
【阿里规约】阿里开发手册解读——数据库和ORM篇
|
1月前
|
SQL Go 数据库
【速存】深入理解Django ORM:编写高效的数据库查询
【速存】深入理解Django ORM:编写高效的数据库查询
59 0
|
3月前
|
SQL Java 数据库连接
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。通过映射机制,它可以自动处理对象与数据库表之间的转换,支持主流数据库,提高了代码的可移植性和可维护性。其核心接口包括 SessionFactory、Session 和 Transaction 等,通过它们可以执行数据库的 CRUD 操作。配置方面,需在项目中引入 Hibernate 及数据库驱动依赖,并创建 `hibernate.cfg.xml` 配置文件来设置数据库连接和 Hibernate 行为参数。
47 1
|
3月前
|
Java 数据库连接 数据库
告别繁琐 SQL!Hibernate 入门指南带你轻松玩转 ORM,解锁高效数据库操作新姿势
【8月更文挑战第31天】Hibernate 是一款流行的 Java 持久层框架,简化了对象关系映射(ORM)过程,使开发者能以面向对象的方式进行数据持久化操作而无需直接编写 SQL 语句。本文提供 Hibernate 入门指南,介绍核心概念及示例代码,涵盖依赖引入、配置文件设置、实体类定义、工具类构建及基本 CRUD 操作。通过学习,你将掌握使用 Hibernate 简化数据持久化的技巧,为实际项目应用打下基础。
214 0
|
3月前
|
数据库 Java 数据库连接
玩转Play Framework的秘密武器:Ebean ORM带你解锁高效数据库操作新姿势,让你的代码从此飞起来!
【8月更文挑战第31天】Play Framework 以其简洁的 API 和高效开发体验著称,Ebean ORM 则是其推荐的对象关系映射(ORM)工具之一。Ebean 可将 Java 对象轻松映射到数据库表,简化数据库交互。本文将指导你在 Play Framework 中使用 Ebean ORM 进行数据库操作,涵盖项目创建、依赖引入、数据库配置、模型定义及 CRUD 操作,并通过示例代码展示实现过程。通过这些步骤,你将学会如何利用 Ebean 的丰富功能,如事务管理、查询构建等,提升 Web 应用的数据库交互能力。
64 0
|
3月前
|
数据库 测试技术 开发者
Play Framework的测试魔法:让代码在舞台上翩翩起舞,确保应用质量的幕后英雄!
【8月更文挑战第31天】Play Framework不仅以其高效开发与部署流程著称,还内置了强大的测试工具,提供全面的测试支持,确保应用高质量和稳定性。本文将详细介绍如何在Play Framework中进行单元测试和集成测试,涵盖`WithApplication`、`WithServer`及`WithDatabase`等类的使用方法,并通过示例代码手把手教你如何利用Play的测试框架。无论是单元测试、集成测试还是数据库操作测试,Play Framework均能轻松应对,助你提升应用质量和开发效率。
45 0
下一篇
无影云桌面