关于NHibernate中实现一对多查询的问题

answerzhang 2008-09-02 02:33:32
啥也不说了出代码
1 Users.hbm.xml
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2">
<class name="Bokun.Examples.Model.Users, Bokun.Examples.Model" table="Users">
<id name="ID" type="int" unsaved-value="null">
<column name="ID" length="4" sql-type="int" not-null="true" unique="true" index="PK_Users"/>
<generator class="native" />
</id>
<property name="UserName" type="String">
<column name="UserName" length="50" sql-type="varchar" not-null="false"/>
</property>
<property name="UserPwd" type="String">
<column name="UserPwd" length="50" sql-type="varchar" not-null="false"/>
</property>
<property name="Sex" type="int">
<column name="Sex" length="4" sql-type="int" not-null="false"/>
</property>
<property name="BirthDay" type="DateTime">
<column name="BirthDay" length="8" sql-type="datetime" not-null="false"/>
</property>
<property name="Email" type="String">
<column name="Email" length="50" sql-type="varchar" not-null="false"/>
</property>
<many-to-one name="Postsex" column="Sex" not-null="true" class="Bokun.Examples.Model.sex"/>
</class>
</hibernate-mapping>
2 sex.hbm.xml
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2">
<class name="Bokun.Examples.Model.sex, Bokun.Examples.Model" table="sexinfo">
<id name="ID" type="int" unsaved-value="null">
<column name="ID" length="4" sql-type="int" not-null="true" unique="true" index="PK_sex"/>
<generator class="native" />
</id>
<property name="Sex" type="String">
<column name="sex" length="60" sql-type="varchar" not-null="false"/>
</property>
<set name="users" inverse="false">
<key column="sexid"/>
<one-to-many class="Bokun.Examples.Model.Users" />
</set>
</class>
</hibernate-mapping>
3 sex.cs
using System;
using System.Collections.Generic;
using System.Text;
using System.Collections;
using Iesi.Collections.Generic;
namespace Bokun.Examples.Model
{
public class sex
{
public sex()
{ }
private int _id;
private string _sex;

public virtual int ID
{
get { return this._id; }
set { this._id = value; }
}
public virtual string Sex
{
get { return this._sex; }
set { this._sex = value; }
}

private ISet<Users> _users=new HashedSet<Users>();
public virtual ISet<Users> Users
{
get { return this._users; }
set { this._users = value;}
}
}
}
4 Users.cs
using System;
using System.Collections.Generic;
using System.Text;

namespace Bokun.Examples.Model
{
public class Users
{
public Users()
{
}
private int _id;
private string _userName;
private string _userPwd;
private int _sex;
private DateTime _birthDay;
private string _email;

/// <summary>
/// 用户名
/// </summary>
public virtual int ID
{
get { return this._id; }
set { this._id = value; }
}

/// <summary>
/// 用户名
/// </summary>
public virtual string UserName
{
get { return this._userName; }
set { this._userName = value; }
}

/// <summary>
/// 用户密码
/// </summary>
public virtual string UserPwd
{
get { return this._userPwd; }
set { this._userPwd = value; }
}

/// <summary>
/// 性别
/// </summary>
public virtual int Sex
{
get { return this._sex; }
set { this._sex = value; }
}

/// <summary>
/// 出生日期
/// </summary>
public virtual DateTime BirthDay
{
get { return this._birthDay; }
set { this._birthDay = value; }
}

/// <summary>
/// Email
/// </summary>
public virtual string Email
{
get { return this._email; }
set { this._email = value; }
}
/// <summary>
/// 集合类
/// </summary>
private Bokun.Examples.Model.sex _postsex;
public virtual Bokun.Examples.Model.sex Postsex
{
get { return this._postsex; }
set { this._postsex = value;}
}
}
}
请问我想显示全部内容将USERS表中的所有数据显示出来把Sex用文字表示出来应该怎么调用?
另外请帮我看看我上面的代码有问题吗?
谢谢大家 帮忙哦
...全文
94 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
西安风影 2008-09-02
  • 打赏
  • 举报
回复
Create Table Parent
(
ParentID int identity primary key,
ParentName varchar(40)
)
Create Table Child
(
ChildID int identity primary key,
ChildName varchar(40),
ParentID int foreign key references Parent(ParentID)
)
protected void Button3_Click ( object sender, EventArgs e )
{
NHibernate.Cfg.Configuration cfg = new NHibernate.Cfg.Configuration ();
cfg.AddAssembly ( "WebNhibernate" );
ISessionFactory factory = cfg.BuildSessionFactory ();
ISession session = factory.OpenSession ();
ITransaction transaction = session.BeginTransaction ();

Parent parent = new Parent ();
parent.ParentName = "Changke";

Child childFirst = new Child ();
childFirst.ChildName = "ChildFirst";
childFirst.Parent = parent;

Child childSecond = new Child ();
childSecond.ChildName = "ChildSecond";
childSecond.Parent = parent;

parent.Childs.Add ( childFirst );
parent.Childs.Add ( childSecond );

session.Save ( parent );
transaction.Commit ();
}

Parent.cs
using System;
using System.Collections.Generic;
using System.Text;

namespace WebNhibernate
{
public class Parent
{
public Parent ()
{
childs = new List<Child> ();
}
private int parentID;
private string parentName;
private IList<Child> childs;

public int ParentID
{
get { return parentID; }
set { parentID = value; }
}

public string ParentName
{
get { return parentName; }
set { parentName = value; }
}

public virtual IList<Child> Childs
{
get { return childs; }
set { childs = value; }
}
}
}

Parent.hbm.xml
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2">
<class name="WebNhibernate.Parent,WebNhibernate" table="Parent" lazy="false">
<id name="ParentID" type="Int32">
<generator class="identity"/>
</id>
<property name="ParentName" type="String"/>
<bag name="Childs" lazy="true" inverse="true" cascade="all">
<key column="ParentID"></key>
<one-to-many class="WebNhibernate.Child,WebNhibernate"/>
</bag>
</class>
</hibernate-mapping>

Child.cs
using System;
using System.Collections.Generic;
using System.Text;

namespace WebNhibernate
{
public class Child
{
public Child ()
{
}
private int childID;
private string childName;
private Parent parent;

public int ChildID
{
get { return childID; }
set { childID = value; }
}

public string ChildName
{
get { return childName; }
set { childName = value; }
}

public Parent Parent
{
get { return parent; }
set { parent = value; }
}
}
}

Child.hbm.xml
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2">
<class name="WebNhibernate.Child,WebNhibernate" table="Child" lazy="false">
<id name="ChildID" type="Int32" unsaved-value="0">
<generator class="identity" />
</id>
<property name="ChildName" type="String"/>
<many-to-one name="Parent" class ="WebNhibernate.Parent, WebNhibernate" column="ParentID"/>
</class>
</hibernate-mapping>
answerzhang 2008-09-02
  • 打赏
  • 举报
回复
没人来帮下我的忙吗?
answerzhang 2008-09-02
  • 打赏
  • 举报
回复
大家帮下忙啊
------------看了绝对不后悔,下载后吱个声--------- 在今日的企业环境,把面向对象的软件和关系数据库一起使用可能是相当麻烦和浪费时间的.NHibernate NHibernate 不仅仅管理.NET类到数据库表的映射(包括.NET 数据类型到SQL数据类型的映射),还提供数据查询和获取数据的方法,可以大幅度减少开发时人工使用SQL和ADO.NET处理数据的时间。   NHibernate的目标主要是用于与数据持久化相关的编程任务,能够使开发人员从原来枯燥的SQL语句的编写解放出来,解放出来的精力可以让开发人员投入到业务逻辑的实现上。对于以数据为心的程序,开发人员往往是在数据库使用存储过程来实现商业逻辑,这种情况下NHibernate可能不是最好的解决方案,但对于那些基于.NET,并且能够实现OO业务模型和商业逻辑的间层应用,NHibernate是最有用的。NHibernate可以帮助用户消除或者包装那些针对特定厂商的SQL代码,并且帮用户把结果集从表格式的表示形式转换成一系列的对象。   NHibernate是一个目前应用的最广泛的开放源代码的对象关系映射框架,它对Java的JDBC(类似于ADO.Net)进行了非常轻量级的对象封装,使得程序员可以随心所欲的使用对象编程思维来操纵数据库,目前在国内Java开发界已经颇为流行,Hibernate+Spring往往是很多Java公司招聘的要求。而NHibernate,顾名思义,如同NUnit,NAnt一样,是基于.Net的Hibernate实现,但是目前介绍NHibernate的资料非常少,缺少一个系统完整的教程来全面的展现和深入NHibernate,而且现在NHibernate的文档又残缺不全,少的可怜,很多NHibernate的学习者往往都是通过Hibernate的文档来学习,但是毕竟不是所有的.Net开发者都熟悉Java,也不是所有的人都有精力有时间去学习Java,所以,我准备开始一个Step by Step的NHibernate教程,以便有兴趣的朋友能够快速的熟悉NHibernate,能够更快地体验NHibernate的开发乐趣。   NHibernate 是一个基于.Net 的针对关系型数据库的对象持久化类库。Nhibernate 来源于非常优秀的基于Java的Hibernate 关系型持久化工具。   NHibernate 从数据库底层来持久化你的.Net 对象到关系型数据库。NHibernate 为你处理这些,远胜于你不得不写SQL去从数据库存取对象。你的代码仅仅和对象关联,NHibernat 自动产生SQL语句,并确保对象提交到正确的表和字段去。
NHibernate 参考文档手册 chm,NHIBERNATE-符合.Net习惯的关系数据库持久化,手册目录摘要:   前言   1. 第一个NHibernate应用程序   1.1. 开始NHibernate之旅   1.2. 第一个持久化类   1.3. 映射cat   1.4. 与Cat同乐   1.5. 总结   2. 体系结构(Architecture)   2.1. 概况(Overview)   2.2. 实例状态   2.3. 上下文相关的(Contextual)Session   3. 配置   3.1. 可编程的配置方式   3.2. 获得ISessionFactory   3.3. 用户自行提供ADO.NET连接   3.4. NHibernate提供ADO.NET连接   3.5. 可选的配置属性   3.5.1. SQL方言   3.5.2 外连接抓取(Outer Join Fetching)   3.5.3. 查询缓存   3.5.4. 查询语言的替换   3.6. 日志   3.7. 实现NamingStrategy   3.8. XML配置文件   4. 持久化类(Persistent Classes)   4.1. 一个简单的POCO例子   4.1.1. 为持久化成员变量声明读写属性   4.1.2. 实现一个默认的构造器(constructor)   4.1.3. 提供一个标识属性(identifier property)(可选)   4.1.4. 使用非不可继承的(non-sealed)类以及虚方法(virtual methods) (可选)   4.2. 实现继承(Inheritance)   4.3. 实现 Equals() 和 GetHashCode() 方法   4.4. 持久化生命周期(Lifecycle)的回调(Callbacks)   4.5. 合法性验证(IValidatable)回调   5. 对象/关系数据库映射基础(Basic O/R Mapping)   5.1. 映射定义(Mapping declaration)   5.1.1. XML名称空间   5.1.2. hibernate-mapping   5.1.3. class   5.1.4. id   5.1.4.1. (主键生成策略)generator   5.1.4.2. 高/低位算法(Hi/Lo Algorithm)   5.1.4.3. 唯一标识16进制算法(UUID Algorithm )   5.1.4.4. 唯一标识字符串算法   5.1.4.5. 唯一标识GUID算法   5.1.4.6. 标识字段和序列(Identity columns and Sequences)   5.1.4.7. 程序分配的标识符(Assigned Identifiers)   5.1.5. (联合主键)composite-id   5.1.6. 鉴别器(discriminator)   5.1.7. 版本(version)(可选)   5.1.8. 时间戳 (可选)   5.1.9. 属性   5.1.10. 多对一   5.1.11. 一对一   5.1.12. 组件(component), 动态组件(dynamic-component)   5.1.13. 子类   5.1.14. 连接的子类(joined-subclass)   5.1.15. 联合子类(union-subclass)   5.1.16. 连接   5.1.17. map, set, list, bag   5.1.18. 引用(import)   5.2. NHibernate 的类型   5.2.1. 实体(Entities)和值(values)   5.2.2. 基本值类型   5.2.3. 自定义值类型   5.2.4. Any类型映射   5.3. SQL引号包围的标识符   5.4. 模块化映射文件   5.5. 数据库生成属性(Generated Properties)   5.6. 数据库辅助对象   6. 集合类(Collections)映射   6.1. 持久化集合类   6.2. 集合外键(Collection foreign keys)   6.3. 值集合于多对多关联(Collections of values and many-to-many associations)   6.4. 一对多关联   6.5. 延迟加载   6.6. 有序集合(Sorted collections)   6.7. 使用   6.8. 双向关联(Bidirectional associations)   6.9. 三重关联(Ternary associations)   6.10. 异质关联(Heterogeneous Associations)   6.11. 集合例子(Collection example)   7. 组件(Component)映射   7.1. 依赖对象(Dependent objects)   7.2. 在集合出现的依赖对象 (Collections of dependent objects)   7.3. 组件作为IDictionary的索引
NHIBERNATE - 符合.Net习惯的关系数据库持久化 NHibernate参考文档 2.0.0 -------------------------------------------------------------------------------- 目录 前言 1. 第一个NHibernate应用程序 1.1. 开始NHibernate之旅 1.2. 第一个持久化类 1.3. 映射cat 1.4. 与Cat同乐 1.5. 总结 2. 体系结构(Architecture) 2.1. 概况(Overview) 2.2. 实例状态 2.3. 上下文相关的(Contextual)Session 3. 配置 3.1. 可编程的配置方式 3.2. 获得ISessionFactory 3.3. 用户自行提供ADO.NET连接 3.4. NHibernate提供ADO.NET连接 3.5. 可选的配置属性 3.5.1. SQL方言 3.5.2 外连接抓取(Outer Join Fetching) 3.5.3. 查询缓存 3.5.4. 查询语言的替换 3.6. 日志 3.7. 实现NamingStrategy 3.8. XML配置文件 4. 持久化类(Persistent Classes) 4.1. 一个简单的POCO例子 4.1.1. 为持久化成员变量声明读写属性 4.1.2. 实现一个默认的构造器(constructor) 4.1.3. 提供一个标识属性(identifier property)(可选) 4.1.4. 使用非不可继承的(non-sealed)类以及虚方法(virtual methods) (可选) 4.2. 实现继承(Inheritance) 4.3. 实现 Equals() 和 GetHashCode() 方法 4.4. 持久化生命周期(Lifecycle)的回调(Callbacks) 4.5. 合法性验证(IValidatable)回调 5. 对象/关系数据库映射基础(Basic O/R Mapping) 5.1. 映射定义(Mapping declaration) 5.1.1. XML名称空间 5.1.2. hibernate-mapping 5.1.3. class 5.1.4. id 5.1.4.1. (主键生成策略)generator 5.1.4.2. 高/低位算法(Hi/Lo Algorithm) 5.1.4.3. 唯一标识16进制算法(UUID Algorithm ) 5.1.4.4. 唯一标识字符串算法 5.1.4.5. 唯一标识GUID算法 5.1.4.6. 标识字段和序列(Identity columns and Sequences) 5.1.4.7. 程序分配的标识符(Assigned Identifiers) 5.1.5. (联合主键)composite-id 5.1.6. 鉴别器(discriminator) 5.1.7. 版本(version)(可选) 5.1.8. 时间戳 (可选) 5.1.9. 属性 5.1.10. 多对一 5.1.11. 一对一 5.1.12. 组件(component), 动态组件(dynamic-component) 5.1.13. 子类 5.1.14. 连接的子类(joined-subclass) 5.1.15. 联合子类(union-subclass) 5.1.16. 连接 5.1.17. map, set, list, bag 5.1.18. 引用(import) 5.2. NHibernate 的类型 5.2.1. 实体(Entities)和值(values) 5.2.2. 基本值类型 5.2.3. 自定义值类型 5.2.4. Any类型映射 5.3. SQL引号包围的标识符 5.4. 模块化映射文件 5.5. 数据库生成属性(Generated Properties) 5.6. 数据库辅助对象 6. 集合类(Collections)映射 6.1. 持久化集合类 6.2. 集合外键(Collection foreign keys) 6.3. 值集合于多对多关联(Collections of values and many-to-many associations) 6.4. 一对多关联 6.5. 延迟加载 6.6. 有序集合(Sorted collections) 6.7. 使用 6.8. 双向关联(Bidirectional associations) 6.9. 三重关联(Ternary associations) 6.10. 异质关联(Heterogeneous Associations) 6.11. 集合例子(Collection example) 7. 组件(Component)映射 7.1. 依赖对象(Dependent objects) 7.2. 在集合出现的依赖对象 (Collections of dependent objects) 7.3. 组件作为IDictionary的索引(Components as IDictionary indices ) 7.4. 组件作为联合标识符(Components as composite identifiers) 7.5. 动态组件 8. 继承映射(Inheritance Mappings) 8.1. 三种策略 8.1.1. 每个类分层结构一张表(Table per class hierarchy) 8.1.2. 每个子类一张表(Table per subclass) 8.1.3. 每个子类一张表(Table per subclass),使用辨别标志(Discriminator) 8.1.4. 混合使用“每个类分层结构一张表”和“每个子类一张表” 8.1.5. 每个具体类一张表(Table per concrete class) 8.1.6. 每个具体类一张表使用隐式多态 8.1.7. 隐式多态和其他继承映射混合使用 8.2. 限制 9. 持久化数据管理 9.1. 创建持久化对象 9.2. 加载载对象 9.3. 查询 9.3.1. 标量(Scalar)查询 9.3.2. IQuery接口 9.3.3. 过滤集合 9.3.4. 条件查询(Criteria queries) 9.3.5. 使用原生SQL的查询 9.4. 修改持久化对象 9.4.1. 使用同一个ISession持久化对象 9.4.2. 修改脱管(Detached)对象 9.4.3. 重新附脱管(Detached)对像 9.5. 删除持久化对象 9.6. 刷出 9.7. 结束ISession 9.7.1. 清除ISession 9.7.2. 提交数据库事务 9.7.3. 关闭ISession 9.8. 异常处理 9.9. 生命周期与对象图 9.10. 拦截器 9.11. 元数据API 10. 事务和并发 10.1. 配置,会话与工厂 10.2. 线程与连接 10.3. 关注对象标识(Considering object identity) 10.4. 乐观并发控制(Optimistic concurrency control) 10.4.1. 长会话自动版本化 10.4.2. 多事务自动版本化 10.4.3. 定制自动版本化行为 10.4.4. 应用程序级别的版本检查(Application version checking) 10.5. 会话断开连接 10.6. 悲观锁定(Pessimistic Locking) 10.7. 连接释放模式(Connection Release Modes) 11. 拦截器与事件 11.1. 拦截器 11.2. 事件系统 12. HQL: NHibernate查询语言 12.1. 大小写敏感性问题 12.2. from子句 12.3. 关联(Association)与连接(Join) 12.4. select子句 12.5. 聚集函数 12.6. 多态查询 12.7. where子句 12.8. 表达式 12.9. order by子句 12.10. group by子句 12.11. 子查询 12.12. HQL示例 12.13. 小技巧 & 小窍门 13. 条件查询(Criteria Queries) 13.1. 创建一个ICriteria实例 13.2. 限制结果集内容 13.3. 结果集排序 13.4. 关联 13.5. 动态关联抓取 13.6. 查询示例 13.7. 投影(Projections)、聚合(aggregation)和分组(grouping) 13.8. 离线(detached)查询和子查询 14. 原生SQL查询 14.1. 使用ISQLQuery 14.1.1. 标量查询(Scalar queries) 14.1.2. 实体查询(Entity queries) 14.1.3. 处理关联和集合类(Handling associations and collections) 14.1.4. 返回多个实体(Returning multiple entities) 14.1.4.1. 别名和属性引用(Alias and property references) 14.1.5. 返回非受管实体(Returning non-managed entities) 14.1.6. 处理继承(Handling inheritance) 14.1.7. 参数(Parameters) 14.2. 命名SQL查询 14.2.1. 使用return-property来明确地指定字段/别名 14.2.2. 使用存储过程来查询 14.2.2.1. 使用存储过程的规则和限制 14.3. 定制SQL用来create,update和delete 14.4. 定制装载SQL 15. 过滤数据 15.1. NHibernate 过滤器(filters) 16. 提升性能 16.1. 抓取策略(Fetching strategies) 16.1.1. 操作延迟加载的关联 16.1.2. 调整抓取策略(Tuning fetch strategies) 16.1.3. 单端关联代理(Single-ended association proxies) 16.1.4. 初始化集合和代理(Initializing collections and proxies) 16.1.5. 使用批量抓取(Using batch fetching) 16.1.6. 使用子查询抓取(Using subselect fetching) 16.2. 二级缓存(The Second Level Cache) 16.2.1. 缓存映射(Cache mappings) 16.2.2. 策略:只读缓存(Strategy: read only) 16.2.3. 策略:读/写缓存(Strategy: read/write) 16.2.4. 策略:非严格读/写缓存(Strategy: nonstrict read/write) 16.2.5. 并发策略兼容性 16.3. 管理缓存(Managing the caches) 16.4. 查询缓存(The Query Cache) 16.5. 理解集合性能(Understanding Collection performance) 16.5.1. 分类(Taxonomy) 16.5.2. Lists, maps 和sets用于更新效率最高 16.5.3. Bag和list是反向集合类效率最高的 16.5.4. 一次性删除(One shot delete) 16.6. 批量更新(Batch updates) 16.7. Multi Query 16.8. 多重条件查询 17. 工具箱指南 17.1. 数据库结构生成(schema generation) 17.1.1. 对schema定制化(Customizing the schema) 17.1.2. 运行该工具 17.1.3. 配置属性(Properties) 17.1.4. 使用NAnt 17.2. 代码生成 17.2.1. 配置文件(可选) 17.2.2. 元数据属性 17.2.3. 基本的finder生成器(Basic finder generator) 17.2.4. 基于Velocity的渲染器/生成器(Velocity based renderer/generator) 17.3. 映射文件生成器(Mapping File Generation) 17.3.1. 运行工具 18. 示例:父子关系(Parent Child Relationships) 18.1. 关于collections需要注意的一点 18.2. 双向的一对多关系(Bidirectional one-to-many) 18.3. 级联生命周期(Cascading lifecycle) 18.4. 使用级联更新 18.5. 结论 19. 示例:Weblog 应用程序 19.1. 持久化类 19.2. NHibernate 映射 19.3. NHibernate 代码 20. 示例:复杂映射实例 20.1. Employer(雇主)/Employee(雇员) 20.2. Author(作家)/Work(作品) 20.3. Customer(客户)/Order(订单)/Product(产品) 21. 最佳实践 I. NHibernateContrib 参考文档 前言 22.2. Prevalence Cache 配置 22.1. 如何使用缓存? 22.2. Prevalence Cache 配置 22.3. SysCache 配置 22.4. SysCache2 配置 22.4.1. 表依赖缓存 22.4.2. SQL依赖缓存 22.4.3. 聚集依赖缓存 22.4.4. 附加设置 22.4.5. 补丁

62,071

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧