Hibernate单表操作的示例分析
这篇文章主要为大家展示了“Hibernate单表操作的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Hibernate单表操作的示例分析”这篇文章吧。
成都创新互联公司是一家集网站建设,南岔企业网站建设,南岔品牌网站建设,网站定制,南岔网站建设报价,网络营销,网络优化,南岔网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。
单一主键
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的长文本数据。
组件属性
实体类中某个属性属于用户自定义的类的对象
如:
也就是说一旦是用户自定义的类型的话,在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
以上是“Hibernate单表操作的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!
本文题目:Hibernate单表操作的示例分析
网站地址:http://myzitong.com/article/gceeoj.html