如何利用NB代码生成工具和NBear框架,快速开发WEB项目

如何利用NB代码生成工具和NBear框架,快速开发WEB项目

NBear是一个.Net 2.0下的快速开发框架。它提供了包括可视化实体设计、代码生成、持久化、SOA、MVP等一系列组件。

NBear的设计目标是尽最大可能减少程序员的重复劳动、提高开发效率、提升代码的可维护性和整体质量。
官方网站:http://nbear.org/
中文教程目录索引:http://www.cnblogs.com/teddyma/archive/2006/11/07/553562. HTML
示例程序:从官方网站下载NBearVXXX_tutorials.zip,解压后见tutorials目录。

本文提到的NBear代码生成工具,主要是配合NBear框架更快速开发项目的一种代码生成工具。主要工具是根据 数据库生成NBear框架中ServiceInterfaces层ServiceImpls层的代码。提高开发效率。接合本身NBear所带的实体生成工具,和配置文件生成工具。加上本文中的这个工具,可以大大提高项目的开发时间,开发人员只用编写跟业务有关的代码,框架相关的代码,基本上这几个工具,都可以自动生成了。

下面详细说明一下如何使用这几个工具来快速开发项目:

一、创建应用程序解决方案

1.1 打开VS2005开发环境,新建一个空的解决方案Solution。

1.2 向Solution中添加两个新建的C#类库工程,两个类库工程的名称分别为EntityDesigns和Entities,删除IDE自动创建的Class1.cs文件。

1.3 向Solution中再添加两个新建的C#类库工程,两个类库工程的名称分别为ServiceInterfaces和ServiceImpls,删除IDE自动创建的Class1.cs文件。





1.4 向Solution 中新建一个名叫WebApplication的 ASP.NET Web应用程序,为WebApplication添加一个Web.config文件。





1.5 项目依赖设置:

WebApplication -> Entities, ServiceInterfaces
ServiceInterfaces -> Entities
ServiceImpls -> Entities, ServiceInterfaces





注:设置完依赖后,记得添加项目引用,并在各项目中添加NB的相关dll

1.6相关引用

WebApplication需:NBear.Common.dll,NBear.Data.dll和NBear.IoC.dll的引用

ServiceInterfacesf需:NBear.Common.dll和NBear.IoC.dll的引用

ServiceImpls 需: NBear.Common.dll,NBear.Data.dll和NBear.IoC.dll的引用

Entities需:NBear.Common. dll

EntityDesigns需:NBear.Common.Design.dll的引用,因为每一个设计实体接口必须继承自NBear.Common.Design.Entity这个接口





记得using

一、从 数据库到实体

1. 运行NBear.Tools.DbToEntityDesign.exe,在Connection String文本框中输入下面的连接子串:Server=(local);Database=Northwind;Uid=sa;Pwd=sa

2. 在EntitiyDesigns工程中新建一个代码文件EntityDesigns.cs,添加using System和using NBear.Common.Design设置namespace为EntityDesigns。并将刚才从DbToEntityDesign复制的代码粘贴至该文件中。



3 下面,对这些生成的代码做一下改造(具体查询NB中文说明书Step 3 设计实体、关系及元数据)





二、从实体设计代码生成实体代码、实体配置文件



3.1编译EntityDesigns工程。
3.2 运行dist目录中的NBear.Tools.EntityDesignToEntity.exe工具,载入EntityDesigns工程编译生成的EntityDesigns.dll。点击Generate Entities按钮,将生成的代码保存到Entities工程中的一个名叫Entities.cs的新代码文件
3.3 点击Generate Configuration按钮,将生成的代码保存到website工程下的名为EntityConfig. XML的新文件中。

三、使用Nbear代码工具生成代码

打开工具后,在系统菜单中找到参数配置。配置好 数据库类型及相应的链接字符串,将项目的顶级名字空间设置好(PX.ServiceInterfaces)那这里要设置成PX,导出路径设置成你项目的根目录(一般是跟解决方案.sln同一路径,这样生成时,代码自动会生成到解决方案的相应目录中,然后在IDE中,点击解决方案上方的显示所有文件按钮,将生成好的.cs包括到项目中就可以了)

工具说明:本工具用在 数据库表很多时,才会发挥大的作用,主要是生成ServiceInterfaces,ServiceImpls这两层的代码,ServiceImpls中使用了partial关键字,用户自己写的代码要放在ServiceUS.cs中,以免当 数据库修改后,二次生成后,把用户自己写在Service里的代码覆盖。

四、使用实体及NBear.Data.Gateway访问 数据库

1.设置website的Web.config文件,添加一个entityConfig section以包含EntityConfig. XML这个实体配置文件,并设置 数据库连接字串。下面是设置完的Web.config,注意,粗体的部分都是我们添加的代码(注意修改 数据库登录密码。):



<?xml version="1.0"?>
<configuration>
<configSections>
<section name="entityConfig" type="NBear.Common.EntityConfigurationSection, NBear.Common" />
</configSections>
<entityConfig>
<includes>
<add key="Sample Entity Config" value="~/EntityConfig.xml" />
</includes>
</entityConfig>
<appSettings/>
<connectionStrings>
<add name="DbName" connectionString="Server=(local);Database=tempdb;Uid=sa;Pwd=sa" providerName="NBear.Data.SqlServer.SqlDbProvider"/>
</connectionStrings>
<castle>
<components>
<component id="Article" service="ServiceInterfaces.IArticleService, ServiceInterfaces" type="ServiceImpls.ArticleService, ServiceImpls"/> <system.web>
<compilation debug="false" />
<authentication mode="Windows" /
</system.web>
</configuration>





5.3 好了,到目前为止,实体设置和配置完毕了。下面我们将开始讨论IoC模块的使用。






具体使用参看DEMO;

你可能感兴趣的:(代码生成)