NHibernate说探——添加,更新,删除

简介: 增改删 ·不再以Northwind为例子,现提供测试数据库Customer 现有数据: CustomerID FirstName     LastName   ·持久类 public class Customer     {         public virtual int Un...

增改删

·不再以Northwind为例子,现提供测试数据库Customer

现有数据:

CustomerID FirstName     LastName

 

·持久类

public class Customer

    {

        public virtual int Unid { get; set; }

        public virtual string FirstName { get; set; }

        public virtual string LastName { get; set; }

    }

·映射

<?xml version="1.0" encoding="utf-8" ?>

<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" assembly="Domain" namespace="Domain.Entities">

  <class name="Customer" table="customer">

    <id name="Unid" column="customerid">

      <generator class="native"></generator>

    </id>

    <property name="FirstName" column="firstname"></property>

    <property name="LastName" column="lastname"></property>

  </class>

</hibernate-mapping>

 

(一)  增(Add

添加一个客户

public void AddCustomer(Customer customer)

        {

            using (ITransaction trans = _session.BeginTransaction())

            {

                try

                {

                    object obj= _session.Save(customer);

                    trans.Commit();

                    Console.WriteLine(obj.ToString());

                }

                catch

                {

                    trans.Rollback();

                    throw;

                }

            }

        }

映射文件中主键生成策略用的是native这个字段的意思:

根据底层数据库的能力选择identity, sequence 或者hilo中的一个。

主键生成类型包括:

·identity使用SQL Server MySQL 的自增字段,由数据库返回,返回类型为intmssql数据库常用的就是这个)

·guid System.Guid实例作为标示符,全名Globally Unique Identifier,全球唯一标识符,格式为xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx,这个也是在mssql中常用的

·uuid.hex用一个System.GuidToString()方法法生成字符串类型的标识符,字符串的长度由format参数定义。[ Hibernate 基于128 UUID 算法 生成16 进制数值(编码后以长度32 的字符串表示)]

·uuid.string 用一个新的System.Guid实例的byte[]转化为字符串作为标示符。

·guid.comb 使用Jimmy Nilsson的算法。GUID也叫UUID,这样的话以上几种uuid.hexuuid.string就好理解

·increment用于为int类型生成唯一标识。只有在没有其他进程往同一张表中插入数据时才能使用。即插入数据的时候hibernate会给主键添加一个自增的主键,但是一个hibernate实例就维护一个计数器,所以在多个实例运行的时候不能使用这个方法

·sequenceDB2,PostgreSQL, Oracle, SAP DB, McKoi中使用序列(sequence) 而在Interbase中使用生成器(generator)。返回的标识符是int类型的。要设定序列名,不然hibernate无法找到:<param   name="sequence">NAME_SEQ</param>

·hilo 使用一个高/低位算法来高效的生成int类型的标识符。给定一个表和字段(默认分别是是hibernate_unique_key next_hi)作为高位值得来源。 /低位算法生成的标识符只在一个特定的数据库中是唯一的。在用户自行提供的连接中,不要使用这种生成器。

·seqhilo 使用一个高/低位算法来高效的生成int类型的标识符,给定一个数据库序列(sequence)的名字。

·assigned 让应用程序在 Save()之前为对象分配一个标示符。即由程序控制生成标识。Hibernate不参与。

·native 根据底层数据库的能力选择identity, sequence 或者hilo中的一个。对于 oracle 采用 Sequence 方式,对于MySQL SQL Server 采用identity(自增主键生成机制),native就是将主键的生成工作交由数据库完成,hibernate不参与管理。

 

1)现在使用identity,效果和现在的native相同,IsessionSave将返回生成的标识。

2)现在使用Guid,数据库表Customer先不改动,还是identity类型的标识。

当使用guid时,

·数据库标识类型,映射类型,持久类型须一致。

·映射文件中guid区分大小写,须为guid

3)现在使用uuid.hex,持久标识类型为string,且数据库标识字段为字符串。

4)再使用一下:assigned,此策略是由程序控制生成唯一标识。这种策略比较灵活,标识类型可以有多种选择,使用这种策略时,添加对象时,应对标识赋值

5)其它几种不再介绍

(二)删除

把主键策略调为indentity

public void DeleteCustomer(Customer customer)

        {

            using (ITransaction trans = _session.BeginTransaction())

            {

                try

                {

                    _session.Delete(customer);

                    trans.Commit();

                }

                catch

                {

                    trans.Rollback();

                    throw;

                }

            }

        }

这里直接删除customer实例。使用ISession.Delete() 会把对象的状态从数据库中移除。当然,你的应用程序可能仍然持有一个指向它的引用。所以,最好这样理解: Delete()的用途是把一个持久化实例变成临时实例。

Delete方法有很多重载,其中就有一个可以添加hibernate查询字符串,用于删除多条记录(这个是容易理解的,查询的内容为实例列表,单实例删除一个实例,列表删除很容易)。删除记录可以不管外键约束,但可能引发外键字段定义的NOT NULL约束冲突。(关于这个外键约束删除在以后说明)

(三)  更新

事务中的持久化实例(就是通过ISession装载、保存、创建或者查询出的对象)可以被程序操作,所做的任何修改都会在ISession同步(flushed)的时候被持久化。

public void UpdateCustomer(Customer customer)

        {

            using (ITransaction trans = _session.BeginTransaction())

            {

                try

                {

                    _session.Update(customer);

                    _session.Flush();

                    trans.Commit();

                }

                catch

                {

                    trans.Rollback();

                    throw;

                }

            }

        }

 

        public Customer GetCustomerById(int iId)

        {

            return _session.Get<Customer>(iId);

        }

        测试更新:

[Test]

        public void TestUpdate()

        {

            //load,持久

            Customer customer = hh.GetCustomerById(3);

 

            //修改

            customer.FirstName = "Jimmy";

 

            //更新

            hh.UpdateCustomer(customer);

        }

 

博客园大道至简

http://www.cnblogs.com/jams742003/

转载请注明:博客园

目录
相关文章
|
6天前
|
存储 关系型数据库 分布式数据库
PostgreSQL 18 发布,快来 PolarDB 尝鲜!
PostgreSQL 18 发布,PolarDB for PostgreSQL 全面兼容。新版本支持异步I/O、UUIDv7、虚拟生成列、逻辑复制增强及OAuth认证,显著提升性能与安全。PolarDB-PG 18 支持存算分离架构,融合海量弹性存储与极致计算性能,搭配丰富插件生态,为企业提供高效、稳定、灵活的云数据库解决方案,助力企业数字化转型如虎添翼!
|
17天前
|
弹性计算 关系型数据库 微服务
基于 Docker 与 Kubernetes(K3s)的微服务:阿里云生产环境扩容实践
在微服务架构中,如何实现“稳定扩容”与“成本可控”是企业面临的核心挑战。本文结合 Python FastAPI 微服务实战,详解如何基于阿里云基础设施,利用 Docker 封装服务、K3s 实现容器编排,构建生产级微服务架构。内容涵盖容器构建、集群部署、自动扩缩容、可观测性等关键环节,适配阿里云资源特性与服务生态,助力企业打造低成本、高可靠、易扩展的微服务解决方案。
1320 7
|
5天前
|
存储 人工智能 Java
AI 超级智能体全栈项目阶段二:Prompt 优化技巧与学术分析 AI 应用开发实现上下文联系多轮对话
本文讲解 Prompt 基本概念与 10 个优化技巧,结合学术分析 AI 应用的需求分析、设计方案,介绍 Spring AI 中 ChatClient 及 Advisors 的使用。
296 129
AI 超级智能体全栈项目阶段二:Prompt 优化技巧与学术分析 AI 应用开发实现上下文联系多轮对话
|
4天前
|
监控 JavaScript Java
基于大模型技术的反欺诈知识问答系统
随着互联网与金融科技发展,网络欺诈频发,构建高效反欺诈平台成为迫切需求。本文基于Java、Vue.js、Spring Boot与MySQL技术,设计实现集欺诈识别、宣传教育、用户互动于一体的反欺诈系统,提升公众防范意识,助力企业合规与用户权益保护。
|
16天前
|
机器学习/深度学习 人工智能 前端开发
通义DeepResearch全面开源!同步分享可落地的高阶Agent构建方法论
通义研究团队开源发布通义 DeepResearch —— 首个在性能上可与 OpenAI DeepResearch 相媲美、并在多项权威基准测试中取得领先表现的全开源 Web Agent。
1392 87
|
4天前
|
JavaScript Java 大数据
基于JavaWeb的销售管理系统设计系统
本系统基于Java、MySQL、Spring Boot与Vue.js技术,构建高效、可扩展的销售管理平台,实现客户、订单、数据可视化等全流程自动化管理,提升企业运营效率与决策能力。
|
5天前
|
人工智能 Java API
AI 超级智能体全栈项目阶段一:AI大模型概述、选型、项目初始化以及基于阿里云灵积模型 Qwen-Plus实现模型接入四种方式(SDK/HTTP/SpringAI/langchain4j)
本文介绍AI大模型的核心概念、分类及开发者学习路径,重点讲解如何选择与接入大模型。项目基于Spring Boot,使用阿里云灵积模型(Qwen-Plus),对比SDK、HTTP、Spring AI和LangChain4j四种接入方式,助力开发者高效构建AI应用。
279 122
AI 超级智能体全栈项目阶段一:AI大模型概述、选型、项目初始化以及基于阿里云灵积模型 Qwen-Plus实现模型接入四种方式(SDK/HTTP/SpringAI/langchain4j)
|
5天前
|
弹性计算 安全 数据安全/隐私保护
2025年阿里云域名备案流程(新手图文详细流程)
本文图文详解阿里云账号注册、服务器租赁、域名购买及备案全流程,涵盖企业实名认证、信息模板创建、域名备案提交与管局审核等关键步骤,助您快速完成网站上线前的准备工作。
231 82
2025年阿里云域名备案流程(新手图文详细流程)