- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个非常奇怪的问题。我编写了一个使用 spring+hibernate 的应用程序。我的 hibernate 配置如下:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.0.xsd">
<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="placeholderPrefix" value="${hospital_"/>
<property name="location" value="hospital.properties"/>
</bean>
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="${hospital_hibernate.driverClassName}"/>
<property name="jdbcUrl" value="${hospital_hibernate.url}"/>
<property name="user" value="${hospital_hibernate.username}"/>
<property name="password" value="${hospital_hibernate.password}"/>
<!--
<property name="acquireIncrement" value="20"/>
<property name="acquireRetryAttempts" value="30"/>
<property name="acquireRetryDelay" value="1000"/>
<property name="autoCommitOnClose" value="true"/>
<property name="checkoutTimeout" value="10000"/>
<property name="debugUnreturnedConnectionStackTraces" value="true"/>
<property name="idleConnectionTestPeriod" value="100"/>
<property name="initialPoolSize" value="1"/>
<property name="maxConnectionAge" value="1000"/>
<property name="maxConnectionAge" value="1000000"/>
<property name="maxIdleTime" value="200"/>
<property name="maxIdleTimeExcessConnections" value="3600"/>
<property name="maxPoolSize" value="10"/>
<property name="minPoolSize" value="1"/>
<property name="preferredTestQuery" value="select 1"/>
<property name="testConnectionOnCheckin" value="false"/>
<property name="unreturnedConnectionTimeout" value="1000"/>
-->
</bean>
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<property name="schemaUpdate" value="${hospital_schema.update}"/>
<property name="mappingResources">
<list>
<value>com/saman/entity/hbms/Employee.hbm.xml</value>
<value>com/saman/entity/hbms/Shift.hbm.xml</value>
<value>com/saman/entity/hbms/Patient.hbm.xml</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">${hospital_hibernate.dialect}</prop>
<prop key="hibernate.show_sql">${hospital_hibernate.showsql}</prop>
<!--<prop key="hibernate.hbm2ddl.auto">update</prop>-->
<prop key="hibernate.generate_statistics">true</prop>
<!--<prop key="hibernate.cache.use_second_level_cache">true</prop>-->
<!--<prop key="hibernate.cache.use_query_cache">true</prop>-->
<!--<prop key="hibernate.cache.region.factory_class">net.sf.ehcache.hibernate.SingletonEhCacheRegionFactory</prop>-->
<!--<prop key="net.sf.ehcache.configurationResourceName">ehcache.xml</prop>-->
<prop key="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</prop>
<prop key="hibernate.use_sql_comments">true</prop>
<prop key="hibernate.transaction.auto_close_session">true</prop>
</props>
</property>
<property name="eventListeners">
<map>
<entry key="merge">
<bean class="org.springframework.orm.hibernate3.support.IdTransferringMergeEventListener"/>
</entry>
</map>
</property>
</bean>
<bean id="txManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"/>
<!--<property name="prepareConnection" value="true"/>-->
<!--<property name="hibernateManagedSession" value="true"/>-->
</bean>
</beans>
我还设置了我的 tx:advice,如下所示:
<tx:advice id="txAdvice" transaction-manager="txManager">
<tx:attributes>
<tx:method name="get*" propagation="REQUIRED" read-only="true"/>
<tx:method name="*" rollback-for="java.lang.Throwable"/>
</tx:attributes>
</tx:advice>
<aop:config>
<aop:pointcut id="transactionServiceOperation"
expression="execution(* com.saman.svc.dalc.IEmployeeDA.*(..))"/>
<aop:pointcut id="transactionServiceOperation2"
expression="execution(* com.saman.svc.dalc.IPatientDA.*(..))" />
<aop:pointcut id="transactionServiceOperation3"
expression="execution(* com.saman.svc.dalc.IShiftDA.*(..))"/>
<aop:advisor advice-ref="txAdvice" pointcut-ref="transactionServiceOperation"/>
<aop:advisor advice-ref="txAdvice" pointcut-ref="transactionServiceOperation2"/>
<aop:advisor advice-ref="txAdvice" pointcut-ref="transactionServiceOperation3"/>
</aop:config>
这里的问题是,当我运行我的应用程序时,对于 10 或 11 个数据库访问它工作正常,但在那之后,我的应用程序似乎被锁定并且不响应。
我真的不知道问题出在哪里。
附:我在 PatientDA、shiftDA 和 employeeDA 类中定义了所有 DA,它们继承了 IPatientDA、IShiftD 和 IEmployeeDA。
我的 GenericDA:
public class GenericDA<TEntity, TId extends Serializable> extends HibernateDaoSupport implements IGenericDA<TEntity, TId>
{
private Boolean isDateString = false;
private Dialect mappingDialect = Dialect.mysql;
public Boolean isDateString()
{
return isDateString;
}
public void setDateString(Boolean dateString)
{
isDateString = dateString == null ? false : dateString;
}
public Dialect getMappingDialect()
{
return mappingDialect;
}
public Dialect dialect()
{
return this.getMappingDialect();
}
public void setMappingDialect(Dialect mappingDialect)
{
this.mappingDialect = mappingDialect;
}
public Class getType()
{
Type tClass = null;
Type type = this.getClass().getGenericSuperclass();
if (type instanceof ParameterizedType)
{
ParameterizedType paramType = (ParameterizedType) type;
tClass = paramType.getActualTypeArguments()[0];
}
return (Class) tClass;
}
public String getStringType()
{
return this.getType().getName();
}
public TEntity get(TId id)
{
return (TEntity) this.getSession().get(getType(), id);
}
public List<TEntity> get()
{
return (List<TEntity>) this.getSession().createCriteria(getType()).list();
}
public List<TEntity> get(long from, long size)
{
return this.getSession().createCriteria(getType())
.setFirstResult((int) from)
.setMaxResults((int) size)
.list();
}
public TEntity insert(TEntity entity)
{
this.getSession().save(entity);
return entity;
}
public TEntity update(TEntity entity)
{
try
{
this.getSession().evict(entity);
this.getSession().update(entity);
//this.getSession().flush();
}
catch (HibernateException ex)
{
this.getSession().evict(entity);
this.getSession().clear();
// this.getSession().update(entity);
throw ex;
}
return entity;
}
public void delete(TId id)
{
this.getSession().delete(get(id));
}
public void delete(TEntity entity)
{
this.getSession().delete(entity);
}
public List<TEntity> get(int from, int size)
{
//noinspection unchecked
return this.getSession().createCriteria(getType())
.setFirstResult(from)
.setMaxResults(size)
.list();
}
public long getCount()
{
return (Long) this.getSession().createQuery("select count(entity.id) from " + getStringType() + " entity")
.uniqueResult();
}
public Object getProperty(Long id, String property)
{
Criteria criteria = this.getSession().createCriteria(getType());
criteria.add(Restrictions.eq("id", id));
criteria.setProjection(Projections.property(property));
criteria.setMaxResults(1);
return criteria.uniqueResult();
}
public org.hibernate.Session prepareFilteredSession(Date effectiveDate)
{
org.hibernate.Session session = this.getSession();
if (effectiveDate != null)
session.enableFilter("effectiveDate").setParameter("fDate", effectiveDate);
return session;
}
public void DisableFilter(org.hibernate.Session session)
{
session.disableFilter("effectiveDate");
}
public String getLikeExpression(String filter, String parameter)
{
String result = "LIKE";
if (filter.startsWith("*"))
{
if (this.mappingDialect.equals(Dialect.oracle))
result += " '%' ||";
else
result += " '%' +";
}
result += " :" + parameter + " ";
if (filter.endsWith("*"))
{
if (this.mappingDialect.equals(Dialect.oracle))
result += " || '%'";
else
result += " + '%'";
}
return result;
}
public String getLikeParameter(String parameter)
{
if (parameter.startsWith("*"))
parameter = parameter.substring(1);
if (parameter.endsWith("*"))
parameter = parameter.substring(0, parameter.length() - 1);
return parameter;
}
public Query setDateParameter(Query query, String name, Date value)
{
if (this.isDateString)
return query.setString(name, String.format("%1$tY-%1$tm-%1$td %tT", value));
else
return query.setParameter(name, value);
}
}
例如我的 ShiftDA 示例是:
public class ShiftDA extends GenericDA<ShiftEntity, Long> implements IShiftDA {
public void updateNumberOfPatients( int numberOfPatients, Long columnID ){
try{
Statement st = this.getSession().connection().createStatement();
String sql = "UPDATE shift SET CurrentNumberOfPatients='" + numberOfPatients + "' WHERE ShiftId='" + columnID.toString() + "' ";
st.executeUpdate(sql);
}catch( Exception e ){
e.printStackTrace();
}
}
}
最佳答案
根据这些 C3P0 设置(最小值 = 1 最大值 = 10)以及您指定的 10 或 11 个请求,我猜测您正在耗尽连接池,因为某些东西没有释放它们。我怀疑这与 tx-manager 有关,它不知道 session 的生命周期何时结束。
另外 - 我会使用公共(public) DBCP 而不是 C3P0。
你能发布 DA 对象正在做什么吗?
关于java - Hibernate 事务不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10654138/
什么是 hibernate 和n- hibernate ?我可以在 Visual Studio 2008 中使用它进行 C# Web 应用程序开发吗?请给我建议...我是 asp.net Web 应用
我有一个不系统地发生的异常(exception)。 我试图通过在每次迭代中刷新和清理 session 来解决此问题,但没有成功。 [quartzScheduler_Worker-7] ERROR jd
使用 Hibernate 在数据库中存储 IP 地址的最佳类型是什么? 我虽然是 Byte[] 或 String,但有没有更好的方法,或者你用什么? @Column(name = "range_fr
我正在尝试制定一个公式来选择用户个人资料的用户友好名称。它选择名字 + ' ' + 姓氏 如果其中至少有一个不为空且不为空(包含非空白字符),否则选择 短名称 (条件相同),最后,如果 短名称 为空或
在hibernate中,是否可以将鉴别器作为一个实体?例如,如果我将 Department 作为基类,将 AdminDepartment 和 ProcessingDepartment 作为子类。 De
我只想从表中获取一些列值。因此,我已经使用投影来实现这一目标。该代码有效,但我认为它无效。 我的问题是当我使用ProjectionsList并将标准条件列表设置为ArrayList时-Bulletin
你好: 我对 hibernate 缓存缓存的内容感到困惑。 从文档中,我知道 hibernate 中有缓存类型。 一级 :交易级别。 似乎要被 session 持久化的实体被缓存在这里。 二级缓存 :
我遇到了一个情况: save或update hibernate 的目标表中的某些数据 在目标表上有一个触发器,该触发器将在目标表的insert或update操作之前执行 由 hibernate 将此记
我有一个名为 Master_Info_tbl 的表。它是一个查询表: 这是该表的代码: @Entity @Table(name="MASTER_INFO_T") public class Code
我想知道如何在 Hibernate 查询语言中使用日期文字。我在我的 JPA 项目中做了如下操作(作为 Eclipselink 提供者)并且它工作正常。 SELECT m FROM Me m WHER
@Entity public class Troop { @OneToMany(mappedBy="troop") public Set getSoldiers() { ...
我正在尝试使用 hibernate 查询删除表 'user_role' 中的所有行。但每次我都会出错。有人可以帮我吗。 DaoImpl @Override public void deleteAll(
不是将数据库操作分散在四个 (osgi) 包中,而是在那里做略有不同的事情。我想创建一个负责所有持久性问题的(简单的)OSGi 包。我觉得这并不像听起来那么简单,因为“每个包都有独特的类加载器”。 因
这就是我使用生成器的方式: private Integer id; 我看到的行为是: 创建第一个对象 hibernate 分配 id = 1 删除该对象 关闭服务
对象级别的实体和值类型有什么区别。我知道实体将有一个 id 但值不会,但为什么我们需要不同的方法来映射实体与值类型? 这样做是为了让hibernate可以对值类型应用任何优化吗? 最佳答案 一个实体已
我正在使用 HibernateTemplate.findByCriteria 方法进行一些查询。现在我想在标准上创建一些 SQL 限制,比如 criteria.add(Restrictions.sql
所以我有以下代码: Query query = session.createQuery("from Weather"); List list = query.list();
如何使用Hibernate映射具有多个实体的 View ? 问候, 混沌 最佳答案 请参见Hibernate文档中第5.1.3节“类”,紧接在“Id”节之前: There is no differen
据我所知,Hibernate 有两种类型的实现 JPA的实现(2)(@Entity,@Table注解) 扩展到旧的(传统的) hibernate (没有 JPA),使用 HSQL 查询,没有注释 如果
我需要一个将条目存储为键值对的集合(因此我可以通过键查找值),但我需要一个允许多个值使用 hibernate 共享同一个键的集合 最佳答案 一个键具有多个值的映射称为多映射 - 在 Apache 公共
我是一名优秀的程序员,十分优秀!