【手撸一个ORM】第一步、实体约定和描述

一、约定

数据实体必须实现 IEntity 接口,该接口定义了一个int类型的Id属性,既每个实体必须有一个名称为Id的自增主键。

若数据表的主键列名称不是Id,可以通过 [MyKey("主键列名")] 对该属性进行描述

namespace MyOrm.Commons
{public interface IEntity{int Id { get; set; }}
}

二、实体描述

MyTableAttribute,用于约定实体和数据表的关联关系,若实体名称和数据表名一直,可省略此描述

MyKeyAttribute,用于约定实体的主键,若数据表主键名称不是Id,可通过此描述约定Id属性映射的数据表的主键名

MyColumnAttribute,InsertIgnore=true 插入时忽略此属性;UpdateIgnore=true 更新时忽略此属性;Ignore=true 插入和更新时忽略该属性;ColumnName 若属性名和列名不一致,使用此属性约定映射的数据表列名

MyForeignKeyAttribute,ForeignKey 用于约定导航属性和外键列,若外键名不为 “导航属性名 + Id”,则需要通过此描述进行约定。

using System;namespace MyOrm.Attributes
{[AttributeUsage(AttributeTargets.Class)]public class MyTableAttribute : Attribute{public string TableName { get; }public MyTableAttribute(string tableName){TableName = tableName;}}[AttributeUsage(AttributeTargets.Property)]public class MyKeyAttribute : Attribute{public bool IsIncrement { get; set; } = true;public string FieldName { get; set; }}[AttributeUsage(AttributeTargets.Property | AttributeTargets.Field)]public class MyColumnAttribute : Attribute{public string ColumnName { get; set; }public bool Ignore { get; set; }public bool InsertIgnore { get; set; }public bool UpdateIgnore { get; set; }}[AttributeUsage(AttributeTargets.Field | AttributeTargets.Property)]public class MyForeignKeyAttribute : Attribute{public string ForeignKey { get; set; }public string MasterKey { get; set; } = "Id";public MyForeignKeyAttribute(string foreignKey){ForeignKey = foreignKey;}}
}

三、示例:

using MyOrm.Attributes;
using MyOrm.Commons;
using System;namespace ConsoleApp1
{// 实体对应的数据表名为 Base_Student[MyTable("Base_Student")]public class Student : IEntity{// 数据表的主键名称为StudentId[MyKey(FieldName = "StudentId")]public int Id { get; set; }public string StudentName { get; set; }public string Mobile { get; set; }public string Card { get; set; }public string State { get; set; }public DateTime? Birthday { get; set; }// 更新时忽略学校Id[MyColumn(UpdateIgnore = true)]public int FKSchoolId { get; set; }// 是否删除字段只能通过 Delete 方法修改,Update时需忽略该属性[MyColumn(UpdateIgnore = true)]public bool IsDel { get; set; }// 创建时间和创建人只在创建时指定,其他时候不能修改[MyColumn(UpdateIgnore = true)]public DateTime CreateAt { get; set; }[MyColumn(UpdateIgnore = true)]public string CreateBy { get; set; }public DateTime UpdateAt { get; set; }public string UpdateBy { get; set; }// 导航属性的外键为 FKSchoolId,若不指定,默认为SchoolId[MyForeignKey("FKSchoolId")]public School School { get; set; }}
}

 

转载于:https://www.cnblogs.com/diwu0510/p/10663275.html

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

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

相关文章

this指向问题(2)

4、显示绑定 指的是apply、bind、call &#xff08;1&#xff09;、apply 和 call 相同点&#xff1a; <1> 这两个方法的用途是在特定的作用域中调用函数&#xff0c;实际上等于设置函数体内 this 对象的值&#xff0c;真正强大之处在于扩充函数赖以运行的作用域 <2&g…

将要被淘汰的8种人

将要被淘汰的8种人 从朋友的空间你发现了这篇文章&#xff0c;觉得写的很有道理&#xff0c;把它转过来&#xff0c;以便时时提醒一下自己&#xff1a; 不景气的社会&#xff0c;一定会淘汰不争气的人。如何不被淘汰&#xff0c;只要你不在这八种人之内。如果你在其中之内&…

学习 AngularJs 终于有点进步了。

很庆幸&#xff0c;自己在7月股市最低点的时候上车了&#xff0c;&#xff0c;开始了在股市的第一票&#xff0c;现在还不知道会不会赚&#xff0c;虽然买的核电有点偏高&#xff0c;但是还是对国家大工业大工程有信心的&#xff0c;按照今天的走势应该赚不少&#xff0c;希望是…

泽西岛2.9及更高版本中的声明式链接

几个星期前几个月前&#xff0c;我正在寻找如何为Oracle Cloud项目设计新的REST API。 我计划要做的事情之一就是使用Marc Hadley在Jersey 1.x中创建的声明性链接注入。 可悲的是这并没有被转发移植然而&#xff0c;这样一个快速的聊天项目带动和我承担了使代码最新的小中型工作…

使用HTML5技术控制电脑或手机上的摄像头

移动设备和桌面电脑上的客户端API起初并不是同步的。最初总是移动设备上先拥有某些功能和相应的API&#xff0c;但慢慢的&#xff0c;这些API会出现在桌面电脑上。其中一个应用接口技术就是getUserMedia API&#xff0c;它能让应用开发者访问用户的摄像头或内置相机。下面就展示…

好的,每个接触Java字节码的人

Oracle诉Google一案认为&#xff0c;复制Java API的结构&#xff0c;序列和组织是侵犯版权的行为。 侵犯版权不仅是复制行为&#xff0c;而且还适用于拥有该作品副本的所有中间方。 那就是编写/编译任何JVM语言的人&#xff0c;以及在他们拥有的任何设备上都有JAR文件的人&…

手动安装boost库

手动安装boost库。 1,下载boost库&#xff0c;解压到目录。我解压的目录为D:\thirdParty。2&#xff0c;build bjam工具。 转到 D:\thirdParty\boost_1_37_0\tools\jam\src目录&#xff0c;执行build.bat即可生成bin.ntx86目录&#xff0c;里面有个bjam.exe&#xff0c;以后bui…

iSlide——图标库、图示库的用法

iSlide中&#xff0c;有一个“图示库”功能&#xff0c;主要功能是同时排列多块文字或多张图片。单击插图库&#xff0c;会弹出一个新的对话框。从中&#xff0c;可以选择权限、分类、数量数据和样式&#xff0c;也可以直接搜索。 下面就举一个例子&#xff1a;我要开一个班队会…

NSMutableDictionary中 setValue和setObject的区别

对于- (void)setValue:(id)value forKey:(NSString *)key;函数 官方解释如下 Send -setObject:forKey: to the receiver, unless the value is nil, in which case send -removeObject:forKey: 这就很明确的说明了setValue&#xff1a;forKey&#xff1a;中value能够为nil&…

IFrame标签的两个用法介绍

1. 作为弹出层铺底覆盖 大家如果做过那种黑色遮罩盖住整张页面&#xff0c;而碰巧用户用的是IE6&#xff0c;更碰巧的是页面上有select元素&#xff0c;那就有得头疼了&#xff08;原理就不在这里赘述了&#xff09;。我们会发现弹出的DIV没法遮住select, 轮到我们的iframe出场…

[C++ rudiment][转]typedef 使用

typedef似乎很简单&#xff0c;如typedef int integer&#xff1b;然而&#xff0c;这些简单的typedef语句容易让人产生一种误解&#xff0c;typedef就是一种宏替换,把后面的自定义类型替换成前面的已知类型&#xff0c;事实是这样的吗?显然不是&#xff01;首先可以肯定的是&…

预留空间过大的OutOfMemoryError

在分配一个应该很适合我为JVM提供的堆中的数据结构时&#xff0c;为什么会出现OutOfMemoryError&#xff1f; 这是我最近遇到的一个问题。 确实&#xff0c;当查看开发人员要完成的工作并通过-Xmx参数对提供给JVM的堆大小进行三重检查时&#xff0c;似乎确实存在着一些可疑之处…

查看系统剩余空间

1.剩余空间&#xff1a;df -h 2.追踪最耗费硬盘的文件位置 cd /du -h --max-depth1 | sort -rn 转载于:https://www.cnblogs.com/xiaobiaomei/p/10669159.html

【转】理解POCO

理解POCO(Plain Old CLR Object)先要理解POJO。 1、什么是POJO? POJO的名称有多种&#xff0c;pure old java object 、plain ordinary java object 等。  按照Martin Fowler的解释是“Plain Old Java Object”&#xff0c;从字面上翻译为“纯洁老式的java对象”&#xff0c…

『ExtJS』01 001. ExtJS 4 类的定义

ExtJS 4 类的定义类的定义与类方法的调用 样例代码// Define new class Vehicle under the Cookbook namespaceExt.define(Cookbook.Vehicle, {// class configuration goes hereManufacturer : Aston Martin,Model : Vanquish,getDetails : function() {alert(I am an this…

HashMap底层实现原理及面试问题

①HashMap的工作原理 HashMap基于hashing原理&#xff0c;我们通过put()和get()方法储存和获取对象。当我们将键值对传递给put()方法时&#xff0c;它调用键对象的hashCode()方法来计算hashcode&#xff0c;让后找到bucket位置来储存值对象。当获取对象时&#xff0c;通过键对象…

Neo4j 2.1:传递节点ID与UNWIND

在发布Neo4j 2.1时&#xff0c;我们将具有UNWIND子句&#xff0c;该子句使处理事物集合更加容易。 在我的有关创建邻接矩阵的博客文章中&#xff0c;我们想要显示按字母顺序排列的前5个见面组中有多少人&#xff0c;然后检查其他各组中有多少人。 没有UNWIND子句&#xff0c;…

使用C#調用外部程式或是執行DOS命令

在.NET裡要如何調用外部程式呢?? 在.net裡&#xff0c;提供了Process類&#xff0c;提供我們強大的調用外部工具功能&#xff0c;並透過重新導向輸入與輸出&#xff0c;可以取得執行結果&#xff0c;下面就用一個例子來示範在一個WinForm裡輸入一個Dos命令&#xff0c;然後呼…

flex 学习篇 ---- 导航类容器

导航类容器需要使用<mx:ViewStack />。可以直接从ui设计器中拉控件过去舞台或者手动敲代码。 导航类容器就是相当于创建了一个菜单&#xff0c;然后按每个选项都可以进入到不同的页面。 创建了<mx:ViewStack>之后需要为它指定id号。 <mx:ViewStack id"vi…

SQLiteOpenHelper+ContentProvider的使用

效果图&#xff1a; PetDbHelper package com.example.admin.pets;import android.content.Context;import android.database.sqlite.SQLiteDatabase;import android.database.sqlite.SQLiteOpenHelper;import com.example.admin.pets.PetContract.PetEntry;public class PetDb…