社区
Web 开发
帖子详情
按查询的会自动UPDATE
finalsyo
2009-04-02 03:05:20
先简单描述情况,有必要的话再贴出程序吧
用的SSH架构
现象很简单,就是我点查询,在页面上显示出一个LIST列表,但是每次执行查询操作后,它会自动执行很多UPDATE语句
想问一问,在什么情况下,它会自动执行UPDATE啊?是我哪里配置的不好吗?
有经验的朋友帮忙解答下 .. 谢谢 ~~
...全文
121
11
打赏
收藏
按查询的会自动UPDATE
先简单描述情况,有必要的话再贴出程序吧 用的SSH架构 现象很简单,就是我点查询,在页面上显示出一个LIST列表,但是每次执行查询操作后,它会自动执行很多UPDATE语句 想问一问,在什么情况下,它会自动执行UPDATE啊?是我哪里配置的不好吗? 有经验的朋友帮忙解答下 .. 谢谢 ~~
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
11 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
finalsyo
2009-04-02
打赏
举报
回复
等 ........................ 还是没找到原因啊 ............
finalsyo
2009-04-02
打赏
举报
回复
大家还有什么建议吗????????????????????
finalsyo
2009-04-02
打赏
举报
回复
[Quote=引用 7 楼 zl_bright 的回复:]
引用 5 楼 finalsyo 的回复:
引用 2 楼 zl_bright 的回复:
你用hibernate从数据库取出的是persistent(持久化)状态对象,
当你对这个对象的操作完成后,
即使没有update操作,hibernate也会自动将这个对象的数据与数据库中的数据同步,
也许你对这个对象进行了某些set操作,
使得这个持久化对象与数据与数据库中的数据不一致,
当session关闭后,hibernate自动更新数据库
那通过配置文件 能关闭这种自动的同步…
[/Quote]
好 可以试一试这个变通的方式
这段代码是我接手别人的...
奇怪的是我的就没有这样的问题
他的就有 所以很想找出问题的根源来..
yztommyhc
2009-04-02
打赏
举报
回复
[Quote=引用 6 楼 finalsyo 的回复:]
引用 4 楼 yztommyhc 的回复:
可能你自己的代码里面有多余的调用,这些调用会执行upadate,仔细检查一下自己的代码。
我想框架一般不会出现什么问题的。
请问多余的调用是指什么调用啊?
我这除了执行一个查询的SQL外没执行别的操作
能举个例子或具体点吗?
[/Quote]
myQuery()
{
query(); // 实际的查询逻辑
update(); //这行用来测试的,但最后你忘记注释了。
}
台城柳月
2009-04-02
打赏
举报
回复
[Quote=引用 5 楼 finalsyo 的回复:]
引用 2 楼 zl_bright 的回复:
你用hibernate从数据库取出的是persistent(持久化)状态对象,
当你对这个对象的操作完成后,
即使没有update操作,hibernate也会自动将这个对象的数据与数据库中的数据同步,
也许你对这个对象进行了某些set操作,
使得这个持久化对象与数据与数据库中的数据不一致,
当session关闭后,hibernate自动更新数据库
那通过配置文件 能关闭这种自动的同步吗?
[/Quote]
这是hibernate的特性,
有一种变通的方法是
不对持久化对象进行set操作,
你可以将该持久化对象clone一个副本
这个副本由于是transient(瞬态)的,不受hibernate控制
你把原来对持久化对象的操作改成对他操作就可以了
绝对不会出现自动更新数据库的情况
finalsyo
2009-04-02
打赏
举报
回复
[Quote=引用 4 楼 yztommyhc 的回复:]
可能你自己的代码里面有多余的调用,这些调用会执行upadate,仔细检查一下自己的代码。
我想框架一般不会出现什么问题的。
[/Quote]
请问多余的调用是指什么调用啊?
我这除了执行一个查询的SQL外没执行别的操作
能举个例子或具体点吗?
finalsyo
2009-04-02
打赏
举报
回复
[Quote=引用 2 楼 zl_bright 的回复:]
你用hibernate从数据库取出的是persistent(持久化)状态对象,
当你对这个对象的操作完成后,
即使没有update操作,hibernate也会自动将这个对象的数据与数据库中的数据同步,
也许你对这个对象进行了某些set操作,
使得这个持久化对象与数据与数据库中的数据不一致,
当session关闭后,hibernate自动更新数据库
[/Quote]
那通过配置文件 能关闭这种自动的同步吗?
yztommyhc
2009-04-02
打赏
举报
回复
可能你自己的代码里面有多余的调用,这些调用会执行upadate,仔细检查一下自己的代码。
我想框架一般不会出现什么问题的。
tianxuejiang123
2009-04-02
打赏
举报
回复
关注!帮你顶一下。
台城柳月
2009-04-02
打赏
举报
回复
你用hibernate从数据库取出的是persistent(持久化)状态对象,
当你对这个对象的操作完成后,
即使没有update操作,hibernate也会自动将这个对象的数据与数据库中的数据
同步
,
也许你对这个对象进行了某些
set
操作,
使得这个持久化对象与数据与数据库中的数据不一致,
当session关闭后,hibernate自动更新数据库
finalsyo
2009-04-02
打赏
举报
回复
在线等 ,,,,,,,,,,,,,,,,,,,,,,
Bluemix开发作品:百科问答
EQA(Encyclopedia QA)是一个汉语知识性问答系统。该系统使用检索与结构化
查询
相合的方法,利离线百度百科数据建立,通过IBM Watson实现
自动
回答。
解决JPA
查询
到的对象属性被set后,
自动
执行
update
解决JPA
查询
到的对象属性被set后,
自动
执行
update
select的for
update
select的for
update
select ...... for
update
查询
校验 select … for
update
查询
select
查询
是不加锁的,select…for
update
是
会
加锁的,而且是悲观锁,但是在不同
查询
条件时候加的锁的类型(行锁,表锁)是不同的。 select * from t_user where id = 1 for
update
; 在where 后面
查询
条件是主键索引,唯一索引时候是行锁
查询
条件是普通字段时候加的是表锁 校验 **首先:**关闭
自动
提交,通过s
用select... for
update
注意事项
今天犯了一个特二的问题,过程如下: 希望首先用select... for
update
进行
查询
,然后根据
查询
的结果对记录逐条的
update
(Proxool连接池),结果发现DB死锁。查了半天最后发现 1. 在select... for
update
的时候用了executeQuery方法
查询
,该方法即使setAutoCommit(true)也不
会
自动
提交,因为
会
被认为不是一个需要up
for
update
和 for
update
nowait 的区别
for
update
和 for
update
nowait 的区别 如果在select语句后加入了for
update
, 则Oracle一旦发现(符合
查询
条件的)这批数据正在被修改,则不
会
发出该select语句
查询
,直到数据被修改结束(被commit),马上
自动
执行这个select语句。 同样,如果该
查询
语句发出后,有人需要修改这批数据(中的一条或几条),它也必须等
Web 开发
81,076
社区成员
341,821
社区内容
发帖
与我相关
我的任务
Web 开发
Java Web 开发
复制链接
扫一扫
分享
社区描述
Java Web 开发
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章