【Hibernate】04 主键策略 & CRUD
实体类编写规范:
- 每个属性不应该被公开的访问,设置私有
- 提供可以访问和设置的方法,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的更多相关文章
- 【hibernate】 hibernate的主键策略
今天使用maven生成一个sping+springMVC+hibernate 的项目,报错如下: 错误提示呢:不能解释这个id的生成策略[uuid.string].就是uuid.string这个hib ...
- hibernate(2) —— 主键策略
框架提供了三种主键生成方式,一种是由用户自己维护,一种是由hibernate框架维护,另一种是由数据库维护. 自己维护就是在插入数据的时候,一定要指定主键的值,否则会出错,如果由框架维护和由数据库维护 ...
- hibernate 注解 主键生成策略
一.JPA通用策略生成器 通过annotation来映射hibernate实体的,基于annotation的hibernate主键标识为@Id, 其生成规则由@GeneratedValue ...
- 大家一起撸代码之——Hibernate各种主键生成策略与配置详解
1.assigned 主键由外部程序负责生成,在 save() 之前必须指定一个.Hibernate不负责维护主键生成.与Hibernate和底层数据库都无关,可以跨数据库.在存储对象前,必须要使用主 ...
- Hibernate中主键生成策略
主键生成策略 increment identity sequence native uuid assigned 1) increment 由hibernate完成 主键递增, 原理:select ma ...
- Hibernate各种主键生成策略与配置详解
出自:http://www.cnblogs.com/kakafra/archive/2012/09/16/2687569.html 1.assigned 主键由外部程序负责生成,在 save() 之前 ...
- Hibernate各种主键生成器策略与配置详解(转载)
http://www.cnblogs.com/kakafra/archive/2012/09/16/2687569.html 1.assigned 主键由外部程序负责生成,在 save() 之前必须指 ...
- Hibernate各种主键生成策略与配置详解《转》
1.assigned 主键由外部程序负责生成,在 save() 之前必须指定一个.Hibernate不负责维护主键生成.与Hibernate和底层数据库都无关,可以跨数据库.在存储对象前,必须要使用主 ...
- Hibernate各种主键生成策略与配置详解【附1--<generator class="foreign">】
1.assigned 主键由外部程序负责生成,在 save() 之前必须指定一个.Hibernate不负责维护主键生成.与Hibernate和底层数据库都无关,可以跨数据库.在存储对象前,必须要使用主 ...
- Hibernate 主键策略
Hibernate主键生成策略 .自动增长identity 适用于MySQL.DB2.MS SQL Server,采用数据库生成的主键,用于为long.short.int类型生成唯一标识 使用SQL ...
随机推荐
- react this指向问题
在JSX事件函数方法中的 this,默认不会绑定 this指向.如果你忘记绑定,当你调用这个函数的时候 this 的值为 undefined.所以使用时一定要绑定好this的指向. 构造方法中绑定 c ...
- 一个简单可分享的web数据透视分析
我推荐一个简单可分享的在线数据透视分析网站,首先看效果: 在线数据透视展示 用户上传一个Excel或csv文件后,把指标拖拽到左右两侧,再选择合适的分析方式,在中间展示区域就会出现分析数据或者图形了, ...
- Python使用Matplotlib画以日期为X轴的图
Python使用Matplotlib画以日期为X轴的图 步骤: 用pd把字符串格式的日期转成date格式. 使用 AutoDateLocator 设置x轴的属性. 1 from matplotlib ...
- arm linux 移植 e2fsprogs
背景 之前在zynq平台下处理系统分区,用到了SPI-FLASH以及EMMC. 根据ZYNQ平台的特性以及产品升级需要,规划了 SPI-FLASH放置BootLoader EMMC中分为2个区,一个F ...
- Java助力加固Excel文件,保障数据安全
前言 Excel文件保护是常用的一种功能,文件保护主要有三种: 添加密码,如果没有密码不允许打开文件. 添加密码,如果没有密码,不能修改文件,但可以打开,只读以及另存文件. 只读推荐,通常推荐打开Ex ...
- 解决python命令行报错问题
解决Python报错Failed calling sys.__interactivehook__ 报错截图 可以看到主要的报错信息 File "D:\Python\Anaconda3\lib ...
- 【资料分享】Xilinx XCZU7EV工业核心板规格书(四核ARM Cortex-A53 + 双核ARM Cortex-R5 + FPGA,主频1.5GHz)
1 核心板简介 创龙科技SOM-TLZU是一款基于Xilinx UltraScale+ MPSoC系列XCZU7EV高性能处理器设计的高端异构多核SoC工业核心板,处理器集成PS端(四核ARM Cor ...
- 【经验分享】全志科技官方Ubuntu16.04根文件系统镜像的替换和测试方法
本文主要基于全志A40i开发板--TLA40i-EVM,一款基于全志科技A40i处理器设计的4核ARM Cortex-A7高性能低功耗国产评估板,演示Ubuntu根文件系统镜像的替换和测试方法. 创 ...
- Go 如何对多个网络命令空间中的端口进行监听
Go 如何对多个网络命令空间中的端口进行监听 需求为 对多个命名空间内的端口进行监听和代理. 刚开始对 netns 的理解不够深刻,以为必须存在一个新的线程然后调用 setns(2) 切换过去,如果有 ...
- 【Error】mysql的error.log中ranges: 268 max_threads: 4 split: 268 depth: 2是什么意思?
2021-12-08T09:36:39.612332+08:00 44213799 [Note] [MY-011825] [InnoDB] Parallel scan: 4 2021-12-08T09 ...