实体类编写规范:

- 每个属性不应该被公开的访问,设置私有

- 提供可以访问和设置的方法,GETTER & SETTER

- 必须编写一个主键属性【ID 唯一值】

- 建议使用基本类型的包装类,因为基本类型不可以表示NULL


主键生成策略:

- HIbernate 要求实体类里面有一个属性作为唯一的值,对应表主键,主键可以不填

<generator class="native" /> <!-- 主键自增策略 -->

- 策略值项:

  1、increment 

    支持long、int、short类型,自增方式的唯一标识,步长1,

    无其他进程插入SQL可使用,不支持多线程操作【脏数据危险】

  2、identity 

    采用数据库底层提供的主键生成标识符,

    必须是数据库支持的数据类型

  3、sequence 

    根据底层数据库序列生成标识符,

    条件是数据库支持序列

  4、native 

    底层数据库对自动生成标识符的能力来选择【2、3、Hilo】其中的一种,

    可跨数据库平台开发

    【生成:主键、非空、自增、int类型】

  5、uuid 

    128位的UUID算法生成标识符,

    绝对唯一标识,占用空间太多

    【生成:主键、非空、VARCHAR类型】

    Java数据类型要使用Java.lang.String

  6、assigned

    由Java程序生成标识符,

    如果没有指定generator元素,默认使用此策略【自然主键】


按ID查询:

    @Test
public void query01(){
Session session = HibernateUtil.getSession(); // 实体类的字节对象,ID值
User user = session.get(User.class, 4);
System.out.println(user);
session.close();
}

修改操作:

先查询,再修改

从思路上是正确的,实际上不需要查询的步骤,

只需要new 一个对象,输入新的字段值和要修改的原始ID

调用UPDATE方法就行了。

另外SAVE也可以用来修改,但是这违背了使用规范,不要这么使用就对了

    @Test
public void query02(){
SessionFactory sessionFactory = HibernateUtil.getSessionFactory();
Session session = sessionFactory.openSession(); Transaction transaction = session.beginTransaction(); // 实体类的字节对象,ID值
User user = session.get(User.class, 4);
System.out.println(user); // 修改字段
user.setUser_name("用户1004"); // 更新操作
session.update(user); transaction.commit();
session.close();
sessionFactory.close();
}

注意:

只修改部分字段,建议使用查询,再改值,在调用修改,因为可以保证其他不变的字段不改动

另外频繁这么修改,性能效率很低,本质上UPDATE是对这个记录完全覆写,

如果数据表一个字段数特别的多,调用修改性能效率真的很低

删除操作:

先查找,后删除

    @Test
public void query03(){
SessionFactory sessionFactory = HibernateUtil.getSessionFactory();
Session session = sessionFactory.openSession(); Transaction transaction = session.beginTransaction(); // 实体类的字节对象,ID值
User user = session.get(User.class, 4);
System.out.println(user); // 删除操作
session.delete(user); transaction.commit();
session.close();
sessionFactory.close();
}

也可以是直接获取ID然后封装给实体类对象

再注入给删除操作

        User user = new User();
user.setUser_id(1); // 删除操作
session.delete(user);

实体类对象的状态

- 瞬时状态 

  对象没有ID值,对象和Session没有关联

- 持久状态

  通过Session获取的,对象和Session具有关联关系

- 托管状态

  对象有ID值,对象和Session没有关系


SaveOrUpdate方法

根据实体类实例的状态来调用不同的操作

- 注入瞬时状态的对象,执行的是添加操作

- 注入托管状态的对象,执行的是修改操作

- 注入持久状态的对象,执行的是修改操作


【Hibernate】04 主键策略 & CRUD的更多相关文章

  1. 【hibernate】 hibernate的主键策略

    今天使用maven生成一个sping+springMVC+hibernate 的项目,报错如下: 错误提示呢:不能解释这个id的生成策略[uuid.string].就是uuid.string这个hib ...

  2. hibernate(2) —— 主键策略

    框架提供了三种主键生成方式,一种是由用户自己维护,一种是由hibernate框架维护,另一种是由数据库维护. 自己维护就是在插入数据的时候,一定要指定主键的值,否则会出错,如果由框架维护和由数据库维护 ...

  3. hibernate 注解 主键生成策略

    一.JPA通用策略生成器       通过annotation来映射hibernate实体的,基于annotation的hibernate主键标识为@Id, 其生成规则由@GeneratedValue ...

  4. 大家一起撸代码之——Hibernate各种主键生成策略与配置详解

    1.assigned 主键由外部程序负责生成,在 save() 之前必须指定一个.Hibernate不负责维护主键生成.与Hibernate和底层数据库都无关,可以跨数据库.在存储对象前,必须要使用主 ...

  5. Hibernate中主键生成策略

    主键生成策略 increment identity sequence native uuid assigned 1) increment 由hibernate完成 主键递增, 原理:select ma ...

  6. Hibernate各种主键生成策略与配置详解

    出自:http://www.cnblogs.com/kakafra/archive/2012/09/16/2687569.html 1.assigned 主键由外部程序负责生成,在 save() 之前 ...

  7. Hibernate各种主键生成器策略与配置详解(转载)

    http://www.cnblogs.com/kakafra/archive/2012/09/16/2687569.html 1.assigned 主键由外部程序负责生成,在 save() 之前必须指 ...

  8. Hibernate各种主键生成策略与配置详解《转》

    1.assigned 主键由外部程序负责生成,在 save() 之前必须指定一个.Hibernate不负责维护主键生成.与Hibernate和底层数据库都无关,可以跨数据库.在存储对象前,必须要使用主 ...

  9. Hibernate各种主键生成策略与配置详解【附1--<generator class="foreign">】

    1.assigned 主键由外部程序负责生成,在 save() 之前必须指定一个.Hibernate不负责维护主键生成.与Hibernate和底层数据库都无关,可以跨数据库.在存储对象前,必须要使用主 ...

  10. Hibernate 主键策略

    Hibernate主键生成策略 .自动增长identity 适用于MySQL.DB2.MS SQL Server,采用数据库生成的主键,用于为long.short.int类型生成唯一标识 使用SQL ...

随机推荐

  1. codemirror-editor-vue3 输入框信息太多 输入框宽度溢出隐藏

    我们把div注释看下之前溢出的效果 因为有form表单在里面任何标签上面设置都是不行 因为有校验要显示校验的信息overflow是不起作用的 要是单独的codemirror-editor-vue3 编 ...

  2. WXS 模块

    https://developers.weixin.qq.com/miniprogram/dev/framework/view/wxs/01wxs-module.html 2.1.概述 WXS(Wei ...

  3. ETL工具-nifi干货系列 第十三讲 nifi处理器QueryDatabaseTable查询表数据实战教程

    1.处理器QueryDatabaseTable,该组件生成一个 SQL 查询,或者使用用户提供的语句,并执行它以获取所有在指定的最大值列中值大于先前所见最大值的行.查询结果将被转换为 Avro 格式, ...

  4. 【Java面试题-基础知识02】Java抽象类和接口六连问?

    1.抽象类和接口分别是什么? 抽象类是一种类,可以包含抽象方法和非抽象方法,抽象方法是没有具体实现的方法,需要在子类中被具体实现. 接口是一种完全抽象的类,其中的所有方法都是抽象方法,没有方法体,它只 ...

  5. 《Android开发卷——HTTP网络通信,HTTP网络连接》

    为了访问互联网,需要设置应用程序获取"androd.permission.INTERNET"权限的许可. 一.使用Apache接口(org.apache.http)并实现网络连接的 ...

  6. raksmart服务器部署SSL报错:ERR_CERT_COMMON_NAME_INVALID

    背景:raksmart服务器 下篇 部署项目 SSL报错:ERR_CERT_COMMON_NAME_INVALID 安装certbot sudo apt update sudo apt install ...

  7. Mysql行转列,列转行 WITH ROLLUP 统计

    Mysql行转列,列转行 WITH ROLLUP 统计 DROP TABLE IF EXISTS tb_score; CREATE TABLE tb_score( id INT(11) NOT NUL ...

  8. 深入了解 C# Span:高性能内存操作的利器

    深入了解 C# Span:高性能内存操作的利器 在 C# 7.2 中引入的 Span<T> 类型为我们提供了一种高效且安全地对内存进行操作的方式.Span<T> 是一个轻量级的 ...

  9. Isolution

    <template> <div style="float:left;width: 100%; margin-left: 0"> <el-row > ...

  10. Sealos 5.0 正式发布,云本应该是操作系统

    把所有资源抽象成一个整体,一切皆应用,这才是云应该有的样子. 2018 年 8 月 15 日 Sealos 提交了第一行代码. 随后开源社区以每年翻倍的速度高速增长. 2022 年我们正式创业,经历一 ...