Hibernate单表操作

简介: 单一主键assigned:由Java应用程序负责生成(即手工的赋值)native:由底层的数据库自动的生成标示符,如果是MySQL就是auto_increment,如果是Oracle就是sequence,等等操作的时候还是需要结合hibernate.cfg.xml文件的,因为数据库中的hbm2ddl.auto属性如果是update的时候,设置为主键自增是可以的;但是如果是create的时候,第二次如果不手工的改变,恐怕就要出BUG了。

单一主键

  • assigned:由Java应用程序负责生成(即手工的赋值)
  • native:由底层的数据库自动的生成标示符,如果是MySQL就是auto_increment,如果是Oracle就是sequence,等等

操作的时候还是需要结合hibernate.cfg.xml文件的,因为数据库中的hbm2ddl.auto属性如果是update的时候,设置为主键自增是可以的;但是如果是create的时候,第二次如果不手工的改变,恐怕就要出BUG了。

基本类型

一般来说,按照Java的数据类型进行操作就可以。
数据类型展示

其中最容易出错的数据类型是date 和 timestamp两种。
- date类型既可以映射成java.util.Date,也可以映射成java.sql.Date类型。代表日期:yyyy-MM-dd
- time类型映射成java.util.Time 和java.sql.Time代表的时间:hh:mm:ss
- timesaamp可以映射成java.util.Date或者java.sql.TimeStamp类型,代表的时间和日期:yyyymmddhhmmss

如何更改其阿紫数据库中的数据库类型呢?

在XX.hbm.xml文件中对class对象的property的type属性进行更改即可。改成Hibernate自带的数据类型就可以了。

对象类型

下面是Hibernate支持的对象类型的总结:
这里写图片描述

操作的时候只需要按照相应的API即可。

需要注意的是MySQL不支持标准的CLOB类型,在MySQL中用TEXT,MEDIUMTEXT及LONGTEXT类型来表示长度超过255的长文本数据。

组件属性

实体类中某个属性属于用户自定义的类的对象

如:
<component name="address" class="Address">
    <property name="postcode" column="POSTCODE" />
    <property name="phone" column="PHONE" />
    <property name="address" column="ADDRESS" />
</component>

也就是说一旦是用户自定义的类型的话,在XX.hbm.xml文件中就要使用component标签,而不是单纯的property标签了。这一点应该有其的注意。

单表操作CRUD的实例

这里主要是使用到了session的几个常用的api。如save,update,delete,和get/load等等。
- save:直接调用session.save(对象的实例)
- get/load:session.get/load(XX.class,标示符);其中这个标示符可以是主键对应的值
- update:session.update(对象的实例)
- delete:session.delete(对象的实例)

get与load的区别:
- 一、不考虑缓存的情况下,get方法在调用之后立即的向数据库发送SQL语句,返回持久化的对象,而load方法会在调用后返回一个代理的对象,该代理对象只保存了实体对象的id,知道适用对象的非主键属性时才会发出sql语句。
- 二、查询数据库中不存在的数据时,get方法返回的是null,load方法则会抛出异常org.hibernate.ObjectNotFoundException

目录
相关文章
|
4月前
|
SQL 缓存 Java
使用Hibernate实现复杂数据库查询优化策略
使用Hibernate实现复杂数据库查询优化策略
|
SQL 缓存 Java
什么是hibernate N+1查询
什么是hibernate N+1查询
|
存储 Oracle 关系型数据库
hibernate在数据库生成hibernate_sequence表问题
hibernate在数据库生成hibernate_sequence表问题
223 0
|
SQL Java 数据库连接
hibernate 根据某一列数据去重
hibernate 根据某一列数据去重
|
XML Java 关系型数据库
Mybatis入门-基于注解实现单表、多表的增删改查
Mybatis入门-基于注解实现单表、多表的增删改查
283 0
|
存储 缓存 Java
【框架】[Hibernate]多表操作与缓存技术
【框架】[Hibernate]多表操作与缓存技术
152 0
|
SQL Java 数据库连接
hibernate的各种查询
Hibernate Query Language(HQL)Criteria QueryNative SQL下面对其分别进行解释select子句:有时并不需要取得对象的所有属性,这时可以使用select子句进行属性查询,如select s.name from Student s。
1006 4
|
Java mybatis 数据库连接
在 Mybatis Plus 的单表操作中 in 的相关问题
之前写过一篇关于 in 与 not in 问题的文章(结合 Mybatis,探讨 Oracle 中 in 与 not in 的陷阱),现在在扩展一下,谈谈 Mybatis Plus 单表操作时 in(not in) 的相关问题。
6173 0
|
SQL Java 数据库连接
|
Java MySQL 关系型数据库
下一篇
无影云桌面