如何实现下面的同步要求?急!100分

beecat 2003-08-13 09:57:49
在sessionBean中,插入方法是用EntityBean实现的,删除方法是用JDBC实现的。应用服务器是Jboss2+Tomcat3,是用了EJB1.1版本。

在实际使用中,发现如果程序中删除了一条记录,马上添加一条相同主键的记录,会抛出 java.lang.IllegalStateException: INSERTING AN ALREADY EXISTING BEAN 例外,同时事务被回滚。

我已经知道这是由于使用JDBC在后台数据库中删除数据,而EntityBean池中的数据没有与数据库同步造成的。但是怎样才能让EntityBean完成这个操作呢?最好对系统的性能没有太大的影响。缩短同步间隔时间不是个好办法,有没有别的办法?比如说在用JDBC删除数据后调用方法同步或在调用EntityBean之前调用方法同步。

请知道如何解决的朋友给出详细的解决方案,谢谢。
100分相送
...全文
22 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
feiyuegaoshan 2003-08-14
  • 打赏
  • 举报
回复
你的逻辑不对。
无论删除还是增加,都应该放到sessionBean内来做。
beecat 2003-08-14
  • 打赏
  • 举报
回复
有没有人救命啊。
beecat 2003-08-14
  • 打赏
  • 举报
回复
原因嘛,我可能要执行根据多个主键删除多条记录的操作啊,如果全部用实体bean来实现的话效率是很低的,而且多个用户操作容易造成死锁。所以我用JDBC来实现,这样效率就高了,速度也快,不容易死锁。

我做的系统记录较多,经常要用到多条记录的操作,比如说删除、检索,尤其是检索。以前用实体bean来实现检索,速度很慢,效率很低,而且多个用户一起查询很容易就死了,所以将删除、检索改成JDBC了。

请大家帮忙解决,如果现在再改成实体bean实现,效率又低了,工作量实在太大,没有办法,还是指望JDBC的删除。希望能够实现同步,解决上述问题。谢谢。
gxg3 2003-08-14
  • 打赏
  • 举报
回复
是啊
你为什么不用实体bean来删除呢?
Morgan_ma 2003-08-13
  • 打赏
  • 举报
回复
你为什么不用实体bean来删除呢?

bean b = home.findByPrimarykey();
b.remove();

不就可以了?

67,513

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧