根据书上配置hibernate一直出错

根据书上配置hibernate一直出错,第1张

童鞋,不要急躁,慢慢来,刚开始都那样坎坷的。

我没看过你说的书,但hib的例子做过一些。

你说的ID Generator,hib可以屏蔽不同数据库,native是指按照你用的数据库的数据库语言,assigned就是特指的,一般都直接用native就可以。

我印象里使用hib的步骤是,首先你数据库建好了,表有了。然后

1)给工程添加hibenate支持,一般用hibnernate 3.1就可以,在添加支持时它会让你选择HibernateSessionFactory.java文件的路径,以及hibernate.hbm.xml文件的路径。

2)修改配置文件,及hibernate.hbm.xml中数据库的连接信息,包括数据库的用户名,密码。

3)反转生成表的映射文件和DAO,数据库连接成功后,在DB Browser里,选中想应数据库,找到表,右键Hiberante Reverse Engineering,由数据库里的表反转生成hbm配置文件,以及根据需要生成DAO(也可以自己手写,更灵活)。

这样就可以通过DAO的数据库表进行增删改查 *** 作了。

1.Hibernate 的初始化. 读取Hibernate 的配置信息-〉创建Session Factory 1)创建Configeration类的实例。 它的构造方法:将配置信息(Hibernate config.xml)读入到内存。

一个Configeration 实例代表Hibernate 所有Java类到Sql数据库映射的集合。 2)创建SessionFactory实例 把Configeration 对象中的所有配置信息拷贝到SessionFactory的缓存中。

SessionFactory的实例代表一个数据库存储员源,创建后不再与Configeration 对象关联。

缓存(cache):指Java对象的属性(通常是一些集合类型的属性--占用内存空间。

SessionFactory的缓存中:Hibernate 配置信息。OR映射元数据。

缓存-大:重量级对象 小:轻量级对象 3)调用SessionFactory创建Session的方法 1】用户自行提供JDBC连接。 Connection con=dataSource.getConnection()

Session s=sessionFactory.openSession(con)2】让SessionFactory提供连接 Session s=sessionFactory.openSession()4)通过Session 接口提供的各种方法来 *** 纵数据库访问。 Hibernate 的缓存体系 一级缓存: Session 有一个内置的缓存,其中存放了被当前工作单元加载的对象。

每个Session 都有自己独立的缓存,且只能被当前工作单元访问。 二级缓存: SessionFactory的外置的可插拔的缓存插件。其中的数据可被多个Session共享访问。 SessionFactory的内置缓存:存放了映射元数据,预定义的Sql语句。 Hibernate 中Java对象的状态 1.临时状态 (transient) 特征:1】不处于Session 缓存中

2】数据库中没有对象记录 Java如何进入临时状态1】通过new语句刚创建一个对象时

2】当调用Session 的delete()方法,从Session 缓存中删除一个对象时。 2.持久化状态(persisted) 特征: 1】处于Session 缓存中

2】持久化对象数据库中设有对象记录

3】Session 在特定时刻会保持二者同步Java如何进入持久化状态 1】Session 的save()把临时-》持久化状态

2】Session 的load(),get()方法返回的对象

3】Session 的find()返回的list集合中存放的对象

4】Session 的update(),saveOrupdate()使游离-》持久化 3.游离状态(detached) 特征:1】不再位于Session 缓存中

2】游离对象由持久化状态转变而来,数据库中可能还有对应记录。 Java如何进入持久化状态-》游离状态 1】Session 的close()方法

2】Session 的evict()方法,从缓存中删除一个对象。提高性能。少用。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/6632819.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-26
下一篇 2023-03-26

发表评论

登录后才能评论

评论列表(0条)

保存