hibernate中查询的数据与数据库不同步问题

hibernate中查询的数据与数据库不同步问题,第1张

你所看到的数据库没反映并不是说数据库没有进行任何的更改

而是数据同步的问题

就像你同时打开两个超作数据库的窗口

在其中一个插入数据,不commit,在另外的窗口就查询不出来

但是在插入窗口是可以查询出来的

hibernate就像是你开的第二个窗口

当然楼上说的很对不修改数据库的数据是不会存在数据不同步的说法的。

这不是hibernate本身的问题哦

建议你看下数据库的知识哦

另外,站长团上有产品团购,便宜有保证

Inverse是hibernate双向关系中的基本概念。inverse的真正作用就是指定由哪一方来维护之间的关联关系。当一方中指定了“inverse=false”(默认),那么那一方就有责任负责之间的关联关系。

Hibernate仅仅按照主控方对象的状态的变化来同步更新数据库。按照原来的映射文 件,people.getAddresses().add(address),即主控方对象的状态发生了改变,因此数据库会跟着对象状态的变化来同步更新 数据库;而address.setPeople(people),即被控方对象的状态发生了改变,它是不能触发对象和数据库的同步更新的。

举个最简单的一对多父子关系。那么代码就写成:

父亲中的关系映射

{set name="children" lazy="true" inverse="true"}

{key column="parent_id"/}

{one-to-many class="test.Child"/}

{/set}

儿子中关系映射

{many-to-one name="parent" column="parent_id" not-null="true"/}

Parent p = new Parent()

Child c = new Child()

c.setParent(p) //维护父子之间关系

p.getChildren().add(c)

session.save(p)

session.flush()

注意:{many-to-one}总是设成“inverse=false”的,而且这个属性在Mapping中是不存在的!

这样运行的下来的结果就是:

Hibernate: insert into parent (id) values (?)

Hibernate: insert into child (parent_id, id) values (?, ?)

那么假如c.setParent(p)注释掉,结果就是:

Hibernate: insert into parent (id) values (?)


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

原文地址: http://outofmemory.cn/sjk/10034148.html

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

发表评论

登录后才能评论

评论列表(0条)

保存