NHibernate在实际项目中的应用

2024-03-28 01:38

本文主要是介绍NHibernate在实际项目中的应用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 剩余油领域模型持久化设计
OOA

通过健壮性分析图和交互图(时序图或协作图)分析用例

以C.1产量递减为例:

[一、读取用例]

 

主成功事件流 
     1、 系统要求用户提供基础数据源:产量递减基础数据

2、 用户提供产量递减基础数据

3、 系统读取产量递减基础数据,要求用户选择递减类型

4、 用户选择递减类型(指数递减、双曲递减、衰减递减)

5、 系统执行产量递减算法产生结果:产量递减结果

[二、建立设计类]

产量递减控制逻辑类:OutputDescendingControl

OutputDescendingControl


[三、运行测试]

编译OutputDescendingDemo项目,产生程序集OutputDescending.dll。用Nunit打开该程序集,运行。

 

错了!很正常。

修改测试类的预测结果改为23.7。


Assert.AreEqual( 23.7 ,(control.Calculate(dataBaseList)  as  ResultofOutputDescending).MaxOutput);


运行,通过。
 
创建与领域模型类相对应的 XML 配置文档和测试类。(可以采用 MyGeneration 自动生成代码,然后进行更改) 起动 MyGeneration ,打开项目模板 Iverson_NHibernate.csgen 。

[四、重构,添加新代码]

    对代码不合理的部分进行重构。

    我们目前完成的是对计算进行测试的代码,计算的基础数据皆采用代理数据。现在我们将其替换成实际使用的数据。在项目中添加Nhibernate引用。

F5运行,配置生成项

 

OK,产生领域模型、XML配置文档和单元测试类 

对生成的代码进行修改。XML配置文档Outputdescendingdatabase.hbm.xml

<? xml version = " 1.0 "  encoding = " utf-8 "   ?>
< hibernate - mapping xmlns = " urn:nhibernate-mapping-2.0 " >
    
< class  name = " OutputDescendingDemo.OutputDescendingDataBase,OutputDescendingDemo "  table = " OUTPUTDESCENDINGDATABASE " >


翻译一下,类OutputDescendingDemo.OutputDescendingDataBase,位于程序集OutputDescendingDemo,它对应于OUTPUTDESCENDINGDATABASE数据表

< id name = " ID "  column = " id "  type = " String " >
            
< generator  class = " uuid.hex " />
</ id >

唯一值,Nhibernate的要求。<generator class="uuid.hex"/>表示生成唯一值的方式是uuid.hex

< property column = " WELLID "  type = " String "  name = " WellID "  not - null = " true "  length = " 100 "   />
< property column = " YEAR "  type = " Single "  name = " Year "  not - null = " true "   />
< property column = " RESULTOFOUTPUT "  type = " Single "  name = " ResultofOutput "  not - null = " true "   />

属性对应的列名,以及类型

</ class >
</ hibernate - mapping >

更改原OutputDescendingDataBase.cs 文件,添加ID字段。对应于Nhibernate的唯一值。或应用自动生成的Outputdescendingdatabase.cs文件替换原文件。替换掉产量递减测试类OutputDescendingFixture中CalculateTest的原有代码。

XML配置文档Outputdescendingdatabase.hbm.xml添加到当前项目中,  设定XML配置文档为嵌入资源

 

在项目的生成目录下创建以程序集为名称的Config文档OutputDescending.dll.config

<? xml version = " 1.0 "  encoding = " utf-8 "   ?>
< configuration >
< configSections >
< section name = " nhibernate "  type = " System.Configuration.NameValueSectionHandler, System, Version=1.0.5000.0,Culture=neutral, PublicKeyToken=b77a5c561934e089 "   />
< section name = " log4net "  type = " log4net.Config.Log4NetConfigurationSectionHandler,log4net "   />
</ configSections >

< nhibernate >
< add
key
= " hibernate.connection.driver_class "
value
= " NHibernate.Driver.OleDbDriver "   />
< add
key
= " hibernate.dialect "
value
= " NHibernate.Dialect.Oracle9Dialect "   />
< add
key
= " hibernate.connection.provider "
value
= " NHibernate.Connection.DriverConnectionProvider "   />
< add
key
= " hibernate.connection.connection_string "
value
= " Provider=MSDAORA.1;user id=ROS;data source=ROSA;password=ROSP "   />
</ nhibernate >
< log4net >
< appender name = " rollingFile "  type = " log4net.Appender.RollingFileAppender,log4net "   >

< param name = " File "  value = " log.txt "   />
< param name = " AppendToFile "  value = " true "   />
< param name = " RollingStyle "  value = " Date "   />
< param name = " DatePattern "  value = " yyyy.MM.dd "   />
< param name = " StaticLogFileName "  value = " true "   />

< layout type = " log4net.Layout.PatternLayout,log4net " >
< param name = " ConversionPattern "  value = " %d [%t] %-5p %c [%x] &lt;%X{auth}&gt; - %m%n "   />
</ layout >
</ appender >
<!--  Setup the root category, add the appenders and  set  the  default  priority  -->
< root >
< priority value = " ALL "   />
< appender - ref   ref = " rollingFile "   />
</ root >
</ log4net >
</ configuration >


更改帐号和数据源,使其适应你的应用程序

 

6、 用户要求系统保存产量递减结果

7、系统保存产量递减结果


[二、绘制健壮性分析图]

绘制健壮性分析图的目的是为了寻找分析类,在用例文本和图形之间寻找一种对应关系,在寻找对应关系的同时,会对需求的整理进行一次正确性和完整性的检查,如果发现问题,重新回到需求进行整理。必要时发起讨论。

[三、绘制交互图]

时序图:

协作图:

根据用例文本绘制时序图,在此注意事件流的顺序。将这种时序性和对象之间寻找关系,转换为协作图。绘制交互图的过程尽可能的不要考虑类的设计,重点关注对象在需求中的交互。将对象中的关系简单的抽象为分析类的职责。如下图所示:

考虑项目组目前的实施。注意与项目组其它成员的合作情况。在需要与其它人进行合作时,安排好自己的迭代计划,在每日开始前的五分钟会议与项目组人员计划当日结对情况。同时对分析类进行简单的设计。比如:

数据源访问接口可以采用Nhibernate完成,而系统的界面部分可以暂时用原型代替。这样我们只需要关心产量递减控制逻辑、产量递减基础数据和产量递减结果。

快速实现初探代码

[一、建立单元测试类]

由以上用例分析可知,我们需要对产量递减基础数据进行计算,然后产生产量递减结果。因此,我们需要对产量递减控制逻辑的计算进行测试。

添加单元测试类

添加单元测试库引用

添加测试代码:OutputDescendingFixture

OutputDescendingFixture

这篇关于NHibernate在实际项目中的应用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/854068

相关文章

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

idea+spring boot创建项目的搭建全过程

《idea+springboot创建项目的搭建全过程》SpringBoot是Spring社区发布的一个开源项目,旨在帮助开发者快速并且更简单的构建项目,:本文主要介绍idea+springb... 目录一.idea四种搭建方式1.Javaidea命名规范2JavaWebTomcat的安装一.明确tomcat

pycharm跑python项目易出错的问题总结

《pycharm跑python项目易出错的问题总结》:本文主要介绍pycharm跑python项目易出错问题的相关资料,当你在PyCharm中运行Python程序时遇到报错,可以按照以下步骤进行排... 1. 一定不要在pycharm终端里面创建环境安装别人的项目子模块等,有可能出现的问题就是你不报错都安装

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

MyCat分库分表的项目实践

《MyCat分库分表的项目实践》分库分表解决大数据量和高并发性能瓶颈,MyCat作为中间件支持分片、读写分离与事务处理,本文就来介绍一下MyCat分库分表的实践,感兴趣的可以了解一下... 目录一、为什么要分库分表?二、分库分表的常见方案三、MyCat简介四、MyCat分库分表深度解析1. 架构原理2. 分

Java 缓存框架 Caffeine 应用场景解析

《Java缓存框架Caffeine应用场景解析》文章介绍Caffeine作为高性能Java本地缓存框架,基于W-TinyLFU算法,支持异步加载、灵活过期策略、内存安全机制及统计监控,重点解析其... 目录一、Caffeine 简介1. 框架概述1.1 Caffeine的核心优势二、Caffeine 基础2

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳

linux查找java项目日志查找报错信息方式

《linux查找java项目日志查找报错信息方式》日志查找定位步骤:进入项目,用tail-f实时跟踪日志,tail-n1000查看末尾1000行,grep搜索关键词或时间,vim内精准查找并高亮定位,... 目录日志查找定位在当前文件里找到报错消息总结日志查找定位1.cd 进入项目2.正常日志 和错误日