小编mwa*_*ngi的帖子

准备好的陈述是否明显减慢了程序?

我正在编写一个软件,要求我准备语句并设置值,执行查询并在循环中获得结果.此循环可能有超过7,000个循环.如果我使用简单语句而不是预处理语句,执行速度会大大改变吗?

这是伪代码

  1. 准备陈述
  2. 从某个地方获取一份清单
  3. 遍历列表
  4. 获取准备好的语句并执行一些db查询并关闭结果集等新资源.
  5. 使用初始列表中的结果和值填充地图

谢谢.

java jdbc prepared-statement

6
推荐指数
1
解决办法
3280
查看次数

每个线程的新连接实例的连接池(JDBC)

我正在创建一个多线程应用程序.但是,当我有一个为所有线程提供服务的连接对象时,我的应用程序遇到了很多意外行为.

我处于两难境地.我应该让每个线程创建,使用和处置自己的连接对象,还是应该使用连接池?

我尝试过连接池,这使得应用程序痛苦地淋浴.但是,我的直觉是,如果我让每个线程都创建自己的连接对象,我可能会遇到"连接太多"的错误.

如果有任何方法可以帮助我,请告诉我.

问候.

java multithreading connection-pooling jdbc

3
推荐指数
1
解决办法
2988
查看次数

Weblogic错误:由以下原因引起:weblogic.transaction.internal.AppSetRollbackOnlyException:在事务上调用setRollbackOnly

我正在将应用程序从Jboss 7as移植到Weblogic 12c.

到目前为止,我能够运行应用程序并在数据库中创建新记录.

但是,我只在尝试更新现有记录时才会收到以下错误;

Error committing transaction:
javax.ejb.TransactionRolledbackLocalException: Error committing transaction: 
at weblogic.ejb.container.internal.EJBRuntimeUtils.throwTransactionRolledbackLocal(EJBRuntimeUtils.java:231)
    at weblogic.ejb.container.internal.EJBRuntimeUtils.throwEJBException(EJBRuntimeUtils.java:134)
    at weblogic.ejb.container.internal.BaseLocalObject.postInvoke1(BaseLocalObject.java:362)
    at weblogic.ejb.container.internal.BaseLocalObject.__WL_postInvokeTxRetry(BaseLocalObject.java:205)
    at weblogic.ejb.container.internal.SessionLocalMethodInvoker.invoke(SessionLocalMethodInvoker.java:46)
    ...
Caused by: weblogic.transaction.internal.AppSetRollbackOnlyException: setRollbackOnly called on transaction
Run Code Online (Sandbox Code Playgroud)

当我javax.persistence.EntityManager.merge(Object)在其事务是容器管理的无状态EJB中调用时,会发生错误.

我最初的想法是容器正在javax.transaction.UserTransaction.setRollbackOnly()某处调用,所以我将EJB的事务管理更改为BMT并自己管理事务.发生了同样的错误.

我怀疑我的Datasource或persistence.xml有问题.

下面是我的persistence.xml的属性

<persistence version="2.0"
         xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="
    http://java.sun.com/xml/ns/persistence
    http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
    <persistence-unit name="myunitname" transaction-type="JTA">
    <provider>org.hibernate.ejb.HibernatePersistence</provider>
    <jta-data-source>myDS</jta-data-source> 
 <properties>
 <property name="hibernate.hbm2ddl.auto" value="update" />
 <property name="hibernate.show_sql" value="false" />
 <property name="hibernate.format_sql" value="false" />
 <property name="hibernate.dialect" value="org.hibernate.dialect.Oracle10gDialect" />
 <property name="hibernate.max_fetch_depth" value="1"/>
 <property name="hibernate.transaction.jta.platform" value="org.hibernate.service.jta.platform.internal.WeblogicJtaPlatform"/>
 </properties>
Run Code Online (Sandbox Code Playgroud)

请协助.

java hibernate weblogic jpa transactions

2
推荐指数
1
解决办法
9787
查看次数

为什么我的应用程序停止运行,而它有一个while(true)循环?

我有一个应用程序,旨在"永远运行".为了实现这一点,我的代码处于一个while(true)循环之下.

while(true){

   //My code is here 
   //What it does is that it calls some Url, 
   //gets xml, parses it and stores the values to a db.

}
Run Code Online (Sandbox Code Playgroud)

此应用程序作为Java应用程序运行,并在Redhat Linux上的jdk 5上运行.一两天后,我意识到日志的活动甚至是5天前,这意味着它在5天前停止工作.但是当我检查机器中的java进程时,此应用程序显示它正在运行.

问题:为什么会这样?

java multithreading

0
推荐指数
1
解决办法
682
查看次数