自定义ORM系列(三)工具雏形及基本用法

简介:

 

引言

  本篇给大家介绍我这个工具的雏形结构,以及基本的用法,还请大家多提意见。

  初看起来,这个有点像NHibernate。说到这里,肯定有人要拍砖了。其实,我也知道。我这个不入流的东西,和NHibernate相比差远了。我开发这个东西的原因主要有两个:

  1)NHibernate太复杂了,学习了两个星期,觉得它太强大了。但是强大是用复杂做代价的,里面要学习的东西太多了,不敢轻易引入项目,因为很多原理不清楚,报错也不明确,所以不敢轻易在项目中使用。

  2)自己想练练手,顺便通过这个过程,也好深入继续深入学习一下NHibernate。因为在写这个工具的过程中,我会看NHibernate的源码,然后看他的源码调用关系,调用逻辑,在自己的工具中模仿它,通过模仿来学习提高。

 

正文

  开始正文吧。写上一幅我目前的工具类图。

 

  

 

 

  基本的调用关系,有点像NHibernate。

  给大家先贴一段使用的示例代码。

 

Custom ORM Code Demo
  // 初始化Session
            ISession session  =   new  Configuration().Configure().BuildSessionFactory().OpenSession();
            Order order 
=   new  Order();
            Guid id 
=  order.OrderID  =  Guid.NewGuid();
            order.ProductName 
=   " seed1221002 "   +  DateTime.Now.ToLongTimeString();
            
// 添加
            session.Save(order);
            session.SubmitChange();
            
// 获取
            order  =   new  Order();
            order 
=  session.Get( new  Guid( " 6744C2AB-C780-4DAD-9089-DF166747640F " ));
            
// 事务操作
             using  (ITransaction tran  =  session.BeginTransaction())
            {
                
try
                {
                    session.Save(order);
                    order.ProductName 
=   " seed1221003 "   +  DateTime.Now.ToLongTimeString();
                    session.Update(order);
                    tran.Commit();
                }
                
catch  (Exception ex)
                {
                    tran.Rollback();
                }
            }

 

  内部具体的数据库操作,目前使用的是Enterprise Library V5.0,感觉使用企业库比较方便。后面的话,如果发现不合适,可以直接用原生的ADO.NET代替就可以了。

  代码:/Files/virusswb/BTFramework.rar

  结合我的 自定义ORM系列(一)利用attribute实现简单的reader=>entity和reader=>List<entity>映射 和 自定义ORM系列(二)发现属性是否修改,有选择的持久化 以及 胡乱说一下我对于 BO VO PO DTO 的理解 中的思想,就可以实现一个完整的基于attribute的ORM小工具,以及有选择的持久化。还可能会极大的减轻系统的维护量。在后面我会将完整版的工具上传,我还会继续完善其他的功能,以及进行一些测试。

 

后话

  如果有哪位有心人,愿意看在下的代码,不嫌弃在下代码乱的话,可以帮我理理思路。因为,我觉得目前的代码结构不是很好,我不知道我这个在实际中使用的话,会遇到什么问题,在哪些地方还需要提高,还需要注意什么,或者说代码的结构那里需要调整?希望有缘人可以指点一二,当然了,胡乱说几句也可以,先谢过了。

  当然了,这个ORM工具我也会继续的完善,希望在下一个项目中可以实践一下。

       项目的SVN地址:svn://www.oksvn.com/BTFramework

       大家可以随意获取,随意使用,随意批评。




本文转自 virusswb 51CTO博客,原文链接:http://blog.51cto.com/virusswb/461380,如需转载请自行联系原作者

目录
相关文章
|
存储 算法 安全
Go反射终极指南:从基础到高级全方位解析
Go反射终极指南:从基础到高级全方位解析
251 0
|
2月前
|
Go API 数据库
Go 语言中常用的 ORM 框架,如 GORM、XORM 和 BeeORM,分析了它们的特点、优势及不足,并从功能特性、性能表现、易用性和社区活跃度等方面进行了比较,旨在帮助开发者根据项目需求选择合适的 ORM 框架。
本文介绍了 Go 语言中常用的 ORM 框架,如 GORM、XORM 和 BeeORM,分析了它们的特点、优势及不足,并从功能特性、性能表现、易用性和社区活跃度等方面进行了比较,旨在帮助开发者根据项目需求选择合适的 ORM 框架。
159 4
|
3月前
|
SQL 关系型数据库 数据库
优化Web开发流程:Python ORM的优势与实现细节
【10月更文挑战第4天】在Web开发中,数据库操作至关重要,但直接编写SQL语句既繁琐又易错。对象关系映射(ORM)技术应运而生,让开发者以面向对象的方式操作数据库,显著提升了开发效率和代码可维护性。本文探讨Python ORM的优势及其实现细节,并通过Django ORM的示例展示其应用。ORM提供高级抽象层,简化数据库操作,提高代码可读性,并支持多种数据库后端,防止SQL注入。Django内置强大的ORM系统,通过定义模型、生成数据库表、插入和查询数据等步骤,展示了如何利用ORM简化复杂的数据库操作。
84 6
|
3月前
|
存储 大数据 Python
案例学Python:filter()函数的用法,高级!
`filter()`函数是Python中处理序列数据的强大工具,它允许我们高效地根据条件过滤元素。通过结合匿名函数、常规函数或直接利用Python的内置逻辑,`filter()`提供了灵活且高效的过滤机制,尤其在大数据处理和内存敏感的应用中展现出其价值。掌握 `filter()`的使用,不仅能提升代码的可读性和效率,还能更好地适应Python的函数式编程风格。
65 2
|
5月前
|
测试技术 Python
Python接口自动化测试框架(基础篇)-- 常用数据类型Number
这篇文章是关于Python接口自动化测试中常用数据类型Number的基础介绍,涵盖了int、float、bool类型以及数学函数和常量的使用,强调了这些数据类型在自动化测试框架中的广泛应用。
34 0
Python接口自动化测试框架(基础篇)-- 常用数据类型Number
|
7月前
|
Java Maven Docker
几种常见的构建模式及其使用方法
几种常见的构建模式及其使用方法
89 3
|
7月前
|
数据库 开发者 Python
Django ORM入门指南:从概念到实践,掌握模型创建、迁移与视图操作
Django ORM入门指南:从概念到实践,掌握模型创建、迁移与视图操作
|
存储 数据可视化 Ubuntu
bcftools学习笔记丨软件简介、安装方式、使用方法、核心功能、参数解释等一文速览
bcftools学习笔记丨软件简介、安装方式、使用方法、核心功能、参数解释等一文速览
|
编译器 C语言 C++
软件开发入门教程网 Search之C++ 类 & 对象
C++ 在 C 语言的基础上增加了面向对象编程,C++ 支持面向对象程序设计。类是 C++ 的核心特性,通常被称为用户定义的类型。
|
数据库 Python
Flask学习与项目实战7:一对一关系、管理表的映射与ORM、项目重构
上篇文章中提到了一对多关系, 也就是一个user对应多篇文章,这是一对多的关系,那么如何设置一对一的关系呢。
Flask学习与项目实战7:一对一关系、管理表的映射与ORM、项目重构