『Spring.NET+NHibernate+泛型』框架搭建之Model(二)
依照搭建项目的顺序来比較好描写叙述一些,我一般先搭建实体层,本节内容纯属于NHibernate范畴。先上图和代码,然后对着图和代码逐一解说,以角色表为例:
T_Role表:
数据库表设计非常easy,ID为主键,而且是自增长的。其它字段还包含角色名称(Name)、描写叙述(Content)、排序(Sort)、状态(Status)、Del(是否删除)。这里就不正确T_Role表赘述了。
T_Role类:
using System; //Nhibernate Code Generation Template 1.0
//author:MythXin
//blog:www.cnblogs.com/MythXin
//Entity Code Generation Template
namespace Model{
//T_Role
public class T_Role
{ /// <summary>
/// ID
/// </summary>
public virtual int ID
{
get;
set;
}
/// <summary>
/// Name
/// </summary>
public virtual string Name
{
get;
set;
}
/// <summary>
/// Content
/// </summary>
public virtual string Content
{
get;
set;
}
/// <summary>
/// Order
/// </summary>
public virtual int? Sort
{
get;
set;
}
/// <summary>
/// 1 启用(默认)
///0 禁用
/// </summary>
public virtual string Status
{
get;
set;
}
/// <summary>
/// 1 正常(默认)
///0 删除
/// </summary>
public virtual string Del
{
get;
set;
} }
}
T_Role类必须与T_Role表的字段一一相应,名字能够不一样,可是字段属性数量和类型必须是一一相应的,此外。每一个字段属性都必须为virtual的。
T_Role表与T_Role的映射文件:
<?xml version="1.0" encoding="utf-8" ? >
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" assembly="Model" >
<class name="Model.T_Role, Model" table="T_Role">
<id name="ID" column="ID" type="int" unsaved-value="0">
<generator class="native"/>
</id>
<property name="Name" type="string" column="Name" />
<property name="Content" type="string" column="Content" />
<property name="Sort" type="int" column="Sort" />
<property name="Status" type="string" column="Status" />
<property name="Del" type="string" column="Del" />
</class>
</hibernate-mapping>
顾名思义,T_Role的映射文件是映射T_Role类和T_Role表的。
注意下面几点:
(1) 必须依照上述格式书写,当中:
a. hibernate-mapping固定上述格式。assembly为文件所在的命名空间;
b. class标签中的name为“T_Role的命名空间.T_Role,T_Role的命名空间”。table为T_Role表的表名。
c. id标签为主键,必须有主键,unsaved-value="0"意思是默认值是0。<generator class="native"/>表示依照数据库定义的方式处理主键,如我定义了自增长。
d. id或property标签中的name为T_Role类中字段名称。而column必须为与之相应的T_Role表的字段名称,且数据类型同样;
(2) 文件必须以.hbm.xml后缀结尾。如:T_Role.hbm.xml;
(3) 必须右键点击文件-属性,将生成操作选为“嵌入的资源
说明:T_Role类文件(.cs文件)和T_Role映射文件(.hbm.xml)按理说能够分别放到不同的目录,可是这样放。执行的时候却提示找不到。最后无奈仅仅能放一起了。要是哪位大神攻克了此问题麻烦留言告知,谢谢。
另外,视图和表的方式全然一样的。映射的时候指定映射的视图即可了。
最后,实体类和映射文件都是能够通过代码生成器生成的,建议不要自己去写。easy出错。还找不出错在哪里,用代码生成器生成之后不正确的改动下就能够了。
我使用的动软代码生成器,代码生成器连接上数据库后。右键相应的数据库选择“模板代码批量生成”,选定要生成的表、模板就能够了,操作非常easy,就不详述了,不清楚的留言,或增加博客签名里的QQ群交流。
贴上Model的文件夹图。并不须要不论什么多余的引用:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast">
『Spring.NET+NHibernate+泛型』框架搭建之Model(二)的更多相关文章
- 『Spring.NET+NHibernate+泛型』框架搭建之DAO(三)★
本节内容介绍Nhibernate所封装的数据库訪问层.只是我增加了泛型进行封装.大概思路:首先,我们有一个接口层,另一个相应的实现层.在接口层中我们先定义一个父接口,父接口中定义每个接口都可能会用到的 ...
- NHibernate框架与BLL+DAL+Model+Controller+UI 多层架构十分相似--『Spring.NET+NHibernate+泛型』概述、知识准备及介绍(一)
原文://http://blog.csdn.net/wb09100310/article/details/47271555 1. 概述 搭建了Spring.NET+NHibernate的一个数据查询系 ...
- MVC+Spring.NET+NHibernate .NET SSH框架整合 C# 委托异步 和 async /await 两种实现的异步 如何消除点击按钮时周围出现的白线? Linq中 AsQueryable(), AsEnumerable()和ToList()的区别和用法
MVC+Spring.NET+NHibernate .NET SSH框架整合 在JAVA中,SSH框架可谓是无人不晓,就和.NET中的MVC框架一样普及.作为一个初学者,可以感受到.NET出了MV ...
- Spring MVC+Spring+Mybatis+MySQL(IDEA)入门框架搭建
目录 Spring MVC+Spring+Mybatis+MySQL(IDEA)入门框架搭建 0.项目准备 1.数据持久层Mybatis+MySQL 1.1 MySQL数据准备 1.2 Mybatis ...
- MVC+Spring.NET+NHibernate .NET SSH框架整合
在JAVA中,SSH框架可谓是无人不晓,就和.NET中的MVC框架一样普及.作为一个初学者,可以感受到.NET出了MVC框架以后太灵活了(相比之前的web Form),嗯,关于.NET中的MVC框架我 ...
- spring + springMVC + spring Data + jpa + maven 项目框架搭建
首先看一下项目结构: 所用到的jar(pom.xml): <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:x ...
- 【面试】足够“忽悠”面试官的『Spring事务管理器』源码阅读梳理(建议珍藏)
PS:文章内容涉及源码,请耐心阅读. 理论实践,相辅相成 伟大领袖毛主席告诉我们实践出真知.这是无比正确的.但是也会很辛苦. 就像淘金一样,从大量沙子中淘出金子一定是一个无比艰辛的过程.但如果真能淘出 ...
- 框架搭建资源 (二) 添加M(模型)
applicationContext.xml <?xml version="1.0" encoding="UTF-8"?> <beans xm ...
- [c#]asp.net开发微信公众平台(2)多层架构框架搭建和入口实现
上篇已经设计出比较完善的数据库了,这篇开始进入代码. 首先把上篇设计的数据库脚本在数据库中执行下,生成数据库,然后在VS中建立项目,为了方便理解和查看,我设计的都是很直白的类名和文件名,没有命名空间 ...
随机推荐
- 知识记忆1:标志寄存器PSW
8086CPU的flag寄存器结构如下: [ ] [ ] [ ] [ ] [OF][DF][IF][TF][SF][ZF][ ][AF][ ][PF][ ][CF] 其中debug中的显示为: 标志 ...
- mysql视图的操作
一.创建视图的语法形式 CREATE VIEW view_name AS 查询语句 ; 使用视图 SELECT * FROM view_name ; 二.创建各种视图 1.封装实现查询常量语句的视图, ...
- 查询分析器执行SQL很快但是ado.net很慢:请为你的SQLparameter设置DbType
我们都知道,参数化查询可以处理SQL注入,以及提高查询的效率,因为参数化查询会使MSSQL缓存查询的计划. 但是会出现一个问题:有的时候参数化查询比直接拼接sql字符串效率低好多,甚至是查询超时. 原 ...
- Laravel5.1学习笔记17 数据库3 数据迁移
介绍 建立迁移文件 迁移文件结构 执行迁移 回滚迁移 填写迁移文件 创建表 重命名/ 删除表 创建字段 修改字段 删除字段 建立索引 删除索引 外键约束 #介绍 Migrations are lik ...
- linux php全能环境一键安装,小白福利!
phpStudy Linux版&Win版同步上线 支持Apache/Nginx/Tengine/Lighttpd/IIS7/8/6 phpStudy for Linux 支持Apache/Ng ...
- React Native应用实现步骤
React Native应用实现步骤 在整个应用设计中,始终按照自下而上的原则进行.在大型的项目中,自下而上的设计方式简单,可以并行工作,并且可以在构建的同时写测试用例. React Native设计 ...
- html5——DOM扩展
元素获取 1.document.getElementsByClassName ('class') 通过类名获取元素,以类数组形式存在. 2.document.querySelector(‘div’) ...
- jQuery——stop
为什么要停止动画? 对同一个元素,如果拥有一个以上的动画对其加以作用,那么后面的动画会被放入一个动画队列中.动画队列的动画是在其上一个动画完成以后才会执行. 控制两个参数四种情况 1.第一个参数表示后 ...
- JS——冒泡案例
模态框 1.因为a链接和和顶级document都注册了单击事件,所以要阻止a链接向父级盒子冒泡,不然又会从document的单击事件走一遍 2.在document的单击事件中,只需要判断触发事件的目标 ...
- SQL基本操作——表的创建
通过代码方式创建数据库 create database MyDatabaseNew on primary ( --名字 name='MyDatabaseNew_data', --路径 filename ...