Nhibernate 多对多级联更新
问题是这样的,有两个表:文章(Article)和分类(Lable),这两者之间的关系是多对多关联,如果你用Nhibernate来保存数据的话非常的好操作,新建Article,然后把Lable值赋值给Article的Lables(这个是在Article类里面有定义的),像这样:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; namespace MyMvc4Project.Models
{
/// <summary>
/// t_Article:实体类(属性说明自动提取数据库字段的描述信息)
/// </summary>
[Serializable]
public class Article
{
/// <summary>
/// id
/// </summary>
public string Id { get; set; } /// <summary>
/// 标题
/// </summary>
public string Title { get; set; } /// <summary>
/// 内容
/// </summary>
public string Contents { get; set; } /// <summary>
/// 点击浏览次数
/// </summary>
public int ClickCount { get; set; } /// <summary>
/// 创建时间
/// </summary>
public DateTime? CreateTime { get; set; } /// <summary>
/// 更新时间
/// </summary>
public DateTime? UpdateTime { get; set; } public IList<Lable> Lables { get; set; }
}
}
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; namespace MyMvc4Project.Models
{
/// <summary>
/// t_Lable:实体类(属性说明自动提取数据库字段的描述信息)
/// </summary>
[Serializable]
public class Lable
{
/// <summary>
/// id
/// </summary>
public string Id { get; set; } /// <summary>
/// 标签名
/// </summary>
public string Name { get; set; } /// <summary>
/// 显示等级
/// </summary>
public int Level { get; set; } /// <summary>
/// 创建时间
/// </summary>
public DateTime? CreateTime { get; set; } /// <summary>
/// 文章
/// </summary>
public IList<Article> Articles { get; set; }
}
}
上面定义的是文章类和分类类别类,现在要保存文章数据,像这样:
Article article =new Article() article.Id=Guid.NewGuid().toString(); article.Title=title; article.Contents=contents; article.CreateTime=DateTime.Now(); article.UpdateTime=DateTime.Now(); article.Lables=lableList; _session.Save(article);
这样的保存好操作,但是我在级联更新的时候遇到问题了,在网上搜索了一下,好像国内使用Nhibernate的人特别少,资料也很少,好像在博客园里Nhibernate比较专业一点的就只有李永京的博客了,不过我没有找到关于级联更新的文章,非常的遗憾。于是我又在官网上查找Nhibernate级联的资料,于是我按照官网上的资料这样操作:
public void Update(Article bean)
{
//这行代码非常的重要,对于nhibernate多对多级联更新
var article = (Article)_session.Load(typeof(Article), bean.Id); var lblList = bean.Lables.Select(
lable => (Lable) _session.Load(typeof (Lable), lable.Id)
).ToList(); article.User = bean.User;
article.Title = bean.Title;
article.Contents = bean.Contents;
article.UpdateTime = DateTime.Now;
article.Lables = lblList;
try
{
_session.Update(article);
_session.Flush();
}
catch (Exception)
{
throw;
}
}
分析:
官网的思路是这样的,先用
var article = (Article)_session.Load(typeof(Article), bean.Id);
通过文章id获取到文章数据,然后再赋值更新,而且所关联的分类数据(Lable)也是这样操作的(先获取后更新),我不知道这样做是不是正确的,也希望博客园里的专家看了我的文章后提出自己的意见或建议,这样我才知道我这样做是不是很完美。
我还在想一个问题,如果所关联的数据有千万条的话,这样关联的更新是不是影响性能?唉,对Nhibernate存在着无数的问题。
Nhibernate 多对多级联更新的更多相关文章
- Nhibernate 多对多级联删除
在网上找到的方法:查看这里 //-------------------------------------Article.hbm.xml-------------------------------- ...
- 【Python】Django数据模型、级联删除、级联更新、ER图导出等
在本文中,我们将向读者详细介绍如何在更新和删除父表数据的同时,触发有关子表数据的级联更新和删除操作.您将看到当使用InnoDB表的时候,借助于外键约束就可以轻松搞定这一过程. 一.利用外键约束更新并删 ...
- 自增特性,外键,级联更新与级联删除,表间关系,SELECT用法,GROUP BY
自增特性 自动增长的作用: 问题:为数据表设置主键约束后,每次插入记录时,如果插入的值已经存在,会插入失败. 如何解决:为主键生成自动增长的值. 自动增长的语法: 字段名 数据类型 AUTO_INCR ...
- SQL图形化操作设置级联更新和删除
SQL级联操作设置 对SQL数据库的表,进行级联操作(如级联更新及删除),首先需要设置表的主外键关系,有两种方法: 第一种: 1. 选择你要进行操作的数据库 2. 为你要创建关系的两个 ...
- mysql级联更新
MySQL 各种级联查询后更新(update select). CREATE TABLE `tb1` ( `id` int(11) NOT NULL, `A` varchar(100) defa ...
- JPA oneToMany 级联更新
oneToMany 使用: 示例:Employee与Phone为例. 1.类定义如下: package com.vrvwh.wh01.domain; import javax.persistence. ...
- 整理sqlserver 级联更新和删除 c#调用存储过程返回值
整理一下级联更新和删除 c#调用返回值 use master go IF exists(select 1 from sysdatabases where name='temp') BEGIN DROP ...
- mysql级联更新的两种方式:触发器更新和外键
1.mysql级联更新有两种方式:触发器更新和外键更新. 2.触发器更新和外键更新的目的都是为了保证数据完整性. 我们通常有这样的需求:删除表Table 1中记录,需要同时删除其它表中与Table 1 ...
- oracle系列--级联删除和级联更新
必须声明:此博客转载于Oracle外键级联删除和级联更新http://www.2cto.com/database/201507/417496.html 鉴于此前收藏的精彩博客无料被删除了,很是痛心,所 ...
随机推荐
- C#基础性问题
解决方案.项目.类之间的关系: 一个解决方案可以包含多个项目.一个项目可以包含多个类 解决方案:公司 项目:部门 类:员工 .sln:解决方案文件,里面包含着整个解决方案的信息,可以双击运行. .cs ...
- tools安装
1.ruby安装 下载安装包 勾选中间一个 2.sass 安装 转换TB镜像 $ gem sources --remove https://rubygems.org/$ gem sources - ...
- echars3.0 柱状图y轴字体斜放
xAxis: [ { type: 'category', axisLabel: { interval: 0, rotate: 45,//倾斜角度设置,是什么时针未测 margin: 2 //距离上部的 ...
- hive 未初始化元数据库报错
启动hive-metastore和hive-server2 用beeline连接hive报错 [root@node04 hive]# beeline Beeline version 0.13.1-cd ...
- vs如何新建自己工程的环境变量(局部)和 Windows系统(全局).
来源:http://blog.csdn.net/jtop0/article/details/7574139 在vs2008的Project->Property设置里经常会看到类似$ ...
- Swift结构体与类
在面向过程的编程语言(如C语言)中,结构体用得比较多,但是面向对象之后,如在C++和Objective-C中,结构体已经很少使用了.这是因为结构体能够做的事情,类完全可以取而代之.而Swift语言却非 ...
- Objective-C(iOS)严格单例模式正确实现
注:本文所有权归作者所有,转载请注明出处 当希望在一个应用程序中某个类的对象只能存在一个的时候就可以考虑用单例模式来实现,单例模式在C++中比较容易实现(只需把构造函数声明为private),而在Ob ...
- 百度或者Google---SEO优化
google和百度的技术差别: 1.百度还认不清哪个是原创的 2.google蜘蛛不够百度快 4.google排名结果随时变化 流量.权重.权威.内容.用户体验.用户关注度等等细节的排名,已表达了SE ...
- (转) Crittercism: 在MongoDB上实现每天数十亿次请求
MongoDB的扩展能力可以满足你业务需求的增长——这也是为什么它的名字来源于单词humongous(极大的)的原因.当然,这并不是说你在 使用MongoDB的路上并不会碰到一些发展的痛点.Critt ...
- 4月10日学习笔记——jQuery选择器
概念 jQuery 是一套Javascript脚本库,注意 jQuery 是脚本库,而不是脚本框架."库"不等于"框架".jQuery 并不能帮助我们解决脚本的 ...