.Net 自己写个简单的 半 ORM (练手)

   ORM 大家都知道, .Net 是EF  还有一些其他的ORM  从JAVA 中移植过来的 有 , 大神自己写的也有 

   不管ORM 提供什么附加的 乱七八糟的功能  

   但是 最主要的 还是 关系映射 的事情。

   我自己一直在使用ORMDapper 这个很小的ORM  第一次看到这个ORM  是通过一个帖子中 有人搞了个常见ORM 效率排行榜 ,自己也试了试  然后就看上 ORMDapper 这个了

   这是把轻量级发挥到极致了! 只有一个 96KB 的 一个Class 文件。其中还有很多是空格和注释信息。 

   

    最近在学习研究JAVA   觉得JAVA 比.NET  有趣点。  也为了 以后 .NET 不行了  还能弄JAVA  

 

    直接上代码:

 

      

        private static string ConnectionString = "**";/// <summary>///  更新数据   没有sql参数就直接执行  /// </summary>/// <param name="sql"> 需要执行的 sql </param>/// <param name="o">传递的实体类对象 要求该类中字段必须和 sql参数名称一致 不区分大小写 </param>/// <returns></returns>public static int UpdateModel(string sql, object o){var s = sql.Split('@');return Update(sql, s.Length == 1 ? null : GetSqlParameters(o, s));}/// <summary>///  查询数据/// </summary>/// <typeparam name="T">映射的实体类</typeparam>/// <param name="sql">执行的SQL语句</param>/// <param name="o">传递的实体类对象 要求该类中字段必须和 sql参数名称一致 不区分大小写 </param>/// <returns></returns>public static List<T> SeleteModel<T>(string sql, object o) where T : class, new(){var s = sql.Split('@');return Select<T>(sql, s.Length == 1 ? null : GetSqlParameters(o, s));}/// <summary>/// 动态创建SqlParameter 对象/// </summary>/// <param name="o">传递的实体类对象 要求该类中字段必须和 sql参数名称一致 不区分大小写 </param>/// <param name="s">切割后的SQL 语句</param>/// <returns></returns>private static SqlParameter[] GetSqlParameters(object o, string[] s){s = s.Select(c => c.Split(' ')[0].Trim()).ToArray(); Type t = o.GetType();if (t == typeof(object))throw new Exception("UpdateModel  传递的类型是OBJECT 类型");// 反射 读取字段 验证是否是 SQL 中的参数var tlist =t.GetFields(BindingFlags.Public | BindingFlags.Instance).Where(c => c.GetValue(o) != null & s.FirstOrDefault(a => a.ToLower() == c.Name.ToLower()) != null).ToList();// 判断得到的数据 是否和 需要的数据 数量一致if (tlist.Count() != s.Count() - 1)throw new Exception("传递的实体中有值参数 和 sql 中需要的 数量不相等");SqlParameter[] sp = new SqlParameter[tlist.Count()];for (int i = 0; i < s.Length - 1; i++){sp[i] = new SqlParameter(s[i + 1].Trim(), tlist.FirstOrDefault(c => c.Name.ToLower() == s[i + 1].ToLower()).GetValue(o));}return sp;}private static List<T> SeleteModel<T>(SqlDataReader data) where T : class, new(){// 获取列 个数int iFieldCount = data.FieldCount;List<T> list = new List<T>();while (data.Read()){T tType = new T();for (int i = 0; i < iFieldCount; i++){// 反射注入字段值string dataName = data.GetName(i);FieldInfo fie = tType.GetType().GetField(dataName);if (fie == null)continue;fie.SetValue(tType, data[dataName]);}list.Add(tType);}return list;}private static List<T> Select<T>(string sql, SqlParameter[] sp) where T : class, new(){using (SqlConnection conn = new SqlConnection(ConnectionString)){using (SqlCommand com = new SqlCommand(sql, conn)){conn.Open();if (sp != null)com.Parameters.AddRange(sp);return SeleteModel<T>(com.ExecuteReader());}}}private static int Update(string sql, SqlParameter[] sp){using (SqlConnection conn = new SqlConnection(ConnectionString)){using (SqlCommand com = new SqlCommand(sql, conn)){conn.Open();if (sp != null) com.Parameters.AddRange(sp); return com.ExecuteNonQuery();}}}

   调用示例:

  

 public class TestCalss{public static void Main(){string sql = @"SELECT TOP 1000 [ID],[ExpressID],[OrderID],[MailCode] ,[SendXML],[SendFlag],[SendCount] FROM [SendStateTest]  where id=@id  and SendXML=@SendXML  ";string sql2 = @"update [DangDang_SendStateTest] set  SendXML='0000' where id=@id     "; int i = AdoConnection.UpdateModel(sql2, new Na() { ID = 1 });List<Na> a = AdoConnection.SeleteModel<Na>(sql, new Na() { ID = 1, SendXML = "0000" });Console.WriteLine(a); }public class Na{ public int ID; public string ExpressID; public string OrderID; public string MailCode;  public string SendXML; public int SendFlag; public int SendCount;} }

  

     只是提供一种自己做一个简单的  三分之一 “ORM” 的  方式   (没有连接池  还得写Sql   )  

     说实话,自己弄的在好,也不如 网上大家都在用的 “ORM” 框架

     可以在这个简单的 “ORM” 上经行加工 拓展,  比如 支持存储过程  不限定数据库  SQL 语句 分类    等等  

     有兴趣的朋友可以自己做做 ,我就不弄了。

     如果你使用过多种ORM 你就会发现 越是功能全 越是强大的ORM 效率就越低    因为不管是哪个ORM 最后还是对JDBC/ADO.NET 的加工封装 。 

     EF 效率是低  但是 他的 是 我弄过的一下ORM框架中 是功能最全 除去效率外 其他都很强大。

 

     

转载于:https://www.cnblogs.com/atliwen/p/4807303.html

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

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

相关文章

synchronized和ReentrantLock的5个区别!

作者 | 磊哥来源 | Java面试真题解析&#xff08;ID&#xff1a;aimianshi666&#xff09;转载请联系授权&#xff08;微信ID&#xff1a;GG_Stone&#xff09;在 Java 中&#xff0c;常用的锁有两种&#xff1a;synchronized&#xff08;内置锁&#xff09;和 ReentrantLock&a…

Java Random nextInt()方法与示例

随机类nextInt()方法 (Random Class nextInt() method) Syntax: 句法&#xff1a; public int nextInt();public int nextInt(int num);nextInt() method is available in java.util package. nextInt()方法在java.util包中可用。 nextInt() method is used to return the nex…

《小强升职记》读后感和思维导图

语言幽默轻松&#xff0c;寓教于乐&#xff0c;看完之后有挽起袖子大干一场的冲动&#xff0c;但是诚如书中所言&#xff0c;“不做收藏家&#xff0c;要做建筑工”&#xff0c;实践和坚持才能有所收获。第一次画思维导图(′▽〃)Xmind格式文件转载于:https://www.cnblogs.com/…

oppo后端16连问

前言 大家好&#xff0c;我是磊哥。最近有位读者去面试了oppo&#xff0c;给大家整理了面试真题的答案。希望对大家有帮助哈&#xff0c;一起学习&#xff0c;一起进步。聊聊你印象最深刻的项目&#xff0c;或者做了什么优化。你项目提到分布式锁&#xff0c;你们是怎么使用分布…

java enummap_Java EnumMap values()方法与示例

java enummapEnumMap类values()方法 (EnumMap Class values() method) values() method is available in java.util package. values()方法在java.util包中可用。 values() method is used to get all the values in a Collection view of this enum map. values()方法用于获取…

django 1.8 官方文档翻译:2-1-1 模型语法

模型 模型是你的数据的唯一的、权威的信息源。它包含你所储存数据的必要字段和行为。通常&#xff0c;每个模型对应数据库中唯一的一张表。 基础&#xff1a; 每个模型都是django.db.models.Model 的一个Python 子类。模型的每个属性都表示数据库中的一个字段。Django 提供一套…

实战!阿里神器 Seata 实现 TCC 模式解决分布式事务

今天这篇文章介绍一下Seata如何实现TCC事务模式&#xff0c;文章目录如下&#xff1a;目录什么是TCC模式&#xff1f;TCC&#xff08;Try Confirm Cancel&#xff09;方案是一种应用层面侵入业务的两阶段提交。是目前最火的一种柔性事务方案&#xff0c;其核心思想是&#xff1…

Java Dictionary get()方法与示例

字典类的get()方法 (Dictionary Class get() method) get() method is available in java.util package. get()方法在java.util包中可用。 get() method is used to get the value on the specified key element (key_ele) in this dictionary. get()方法用于获取此字典中指定键…

[CareerCup] 8.10 Implement a Hash Table 实现一个哈希表

8.10 Design and implement a hash table which uses chaining (linked lists) to handle collisions. 这道题让我们实现一个简单的哈希表&#xff0c;我们采用了最简单的那种取余映射的方式来实现&#xff0c;我们使用Cell来保存一对对的key和value的映射关系&#xff0c;然后…

Spring Boot 中实现跨域的 5 种方式,你一定要知道!

一、为什么会出现跨域问题出于浏览器的同源策略限制。同源策略&#xff08;Sameoriginpolicy&#xff09;是一种约定&#xff0c;它是浏览器最核心也最基本的安全功能&#xff0c;如果缺少了同源策略&#xff0c;则浏览器的正常功能可能都会受到影响。可以说Web是构建在同源策略…

stl:queue 源码_C ++ STL中的queue :: empty()和queue :: size()

stl:queue 源码In C STL, Queue is a type of container that follows FIFO (First-in-First-out) elements arrangement i.e. the elements which inserts first will be removed first. In queue, elements are inserted at one end known as "back" and are delet…

术中导航_密码术中的计数器(CTR)模式

术中导航The Counter Mode or CTR is a simple counter based block cipher implementation in cryptography. Each or every time a counter initiated value is encrypted and given as input to XOR with plaintext or original text which results in ciphertext block. Th…

Android社交类APP动态详情代码实现通用模板

&#xfeff;&#xfeff;Android社交类APP动态详情代码实现通用模板 Android平台上一些比较流行的社交类APP比如微信、陌陌等&#xff0c;都有动态详情页&#xff0c;在该页面&#xff0c;用户发表的动态详情&#xff0c;好友可以发起评论、点赞等等。这种设计在微信和陌陌上大…

聊聊并发编程的12种业务场景

前言并发编程是一项非常重要的技术&#xff0c;无论在面试&#xff0c;还是工作中出现的频率非常高。并发编程说白了就是多线程编程&#xff0c;但多线程一定比单线程效率更高&#xff1f;答&#xff1a;不一定&#xff0c;要看具体业务场景。毕竟如果使用了多线程&#xff0c;…

软件工程编码阶段_软件工程的编码阶段

软件工程编码阶段The coding phase in the software engineering paradigm is usually defined after the designing phase. In this phase, the developers or the coders have to implement the software design practically using any computer language(s) so that the sof…

梳理50道经典计算机网络面试题

我梳理了50道计算机网络面试题&#xff0c;每一道题目都特别经典&#xff0c;大厂也非常喜欢问。相信大家看完&#xff0c;会有新的收获滴~1. 说说HTTP常用的状态码及其含义&#xff1f;思路: 这道面试题主要考察候选人&#xff0c;是否掌握HTTP状态码这个基础知识点。不管是不…

A successful Git branching model

原文&#xff1a;http://nvie.com/posts/a-successful-git-branching-model/ In this post I present the development model that I’ve introduced for all of my projects (both at work and private) about a year ago, and which has turned out to be very successful. I…

一文详解读写锁

作者 | 磊哥来源 | Java面试真题解析&#xff08;ID&#xff1a;aimianshi666&#xff09;转载请联系授权&#xff08;微信ID&#xff1a;GG_Stone&#xff09;读写锁&#xff08;Readers-Writer Lock&#xff09;顾名思义是一把锁分为两部分&#xff1a;读锁和写锁&#xff0c…

ruby array_Ruby中带有示例的Array.keep_if方法

ruby arrayRuby Array.keep_if方法 (Ruby Array.keep_if Method) In the last articles, we have studied the Array methods namely Array.select, Array.reject and Array.drop_while, all these methods are non–destructive methods which means that they do not impose …

[实战]MVC5+EF6+MySql企业网盘实战(2)——用户注册

写在前面 上篇文章简单介绍了项目的结构&#xff0c;这篇文章将实现用户的注册。当然关于漂亮的ui&#xff0c;这在追后再去添加了&#xff0c;先将功能实现。也许代码中有不合适的地方&#xff0c;也只有在之后慢慢去优化了。 系列文章 [EF]vs15ef6mysql code first方式 [实战…