JSP 开发之 releaseSession的实例详解
作者:lqh 发布时间:2023-06-14 11:49:03
标签:JSP,releaseSession
JSP 开发之 releaseSession的实例详解
Hibernate可以实现分页查询,昨天试了一下,分页效果不错。但是发现了一个问题,就是当请求超过20次的时候页面就会卡死。经检查,是卡在分页查询这一块。
应用程序采用struts2 + spring2 + hibernate3架构
连接池配置使用的是c3p0,最大池大小为20, 很显然是连接池耗尽导致的。增加连接池大小只是饮鸩止渴,总还有耗尽的时候,必须找到根本原因。
Dao类的分页查询方法如下:
java 代码
public List getTopics(int perPageStartNum, int perPageShowNum, long f_id) {
Query query = getSession().createQuery("from Topic where forumId=" + f_id);
query.setFirstResult(perPageStartNum);
query.setMaxResults(perPageShowNum);
return query.list();
}
我尝试在获得list之后,使用getSession().close()关闭,没有效果。
早上来上班继续调试,问题依旧。仔细想想可能还是对于spring中集成的操作hibernatesession 的方法不熟悉。
查阅Spring API:
geSession()是org.springframework.orm.hibernate3.support.HibernateDaoSupport 中的一个方法,
它可以从当前事务或者一个新的事务获得一个hibernatesession.
通常使用releaseSession(org.hibernate.Session)方法与getSession()配合。
如果没有绑定线程,releaseSession关闭由这个DAO的SessionFactory创建的Hibernate Session。
修改后的代码为:
public List getTopics(int perPageStartNum, int perPageShowNum, long f_id) {
Session session = getSession();
List list = session.createQuery("from Topic where forumId=" + f_id)
.setFirstResult(perPageStartNum)
.setMaxResults(perPageShowNum)
.list();
releaseSession(session);
return list;
}
启动服务器测试,问题解决。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
来源:http://blog.csdn.net/johnstrive/article/details/5512352


猜你喜欢
- 开发环境:win10-64 python2.7.16 chrome77from selenium import we
- 1.参数propsprops是一个对象,包含父组件传递给子组件的所有数据。在子组件中使用props进行接收。包含配置声明并传入的所有的属性的
- 组建一个关于书籍、作者、出版社的例子:from django.db import modelsclass Publisher(models.
- Google网站管理员工具的验证方式有两种,一个是通过html文件,或一种是通过meta标签。通常情况下,这两个方式直接就可以通过验证了。但
- nofollow标签是Google2005年推出的,目的是尽量减少垃圾链接对搜索引擎的影响。有用过网页制作工具的人都知道,在这些工具里是找不
- 前言首先简单说一下虚拟环境的概念。虚拟环境是由基础环境创建而出,用于独有项目的开发,每个项目都应该有一个独有的环境。第一步检查是否安装Pyt
- pymsqlpymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎相同。下载安装pip3 install pymy
- join用来连接字符串,split恰好相反,拆分字符串的。不用多解释,看完代码,其意自现了。>>>li = ['m
- 背景介绍作为一款产品,往往希望能得到用户的反馈,从而通过对用户行为的分析进行功能、交互等方面的改进。然而直接的一对一的用户交流是低效且困难的
- 1、解压到想要安装的位置,创建my.ini文件my.ini的内容如下[mysql]# 设置mysql客户端默认字符集default-char
- 先看一下br怎么玩转“清除浮动”了。使用以下代码<br clear="all" />以下是代码效果演示:运行
- 事务控制的核心——Connection在开始之前,先让我们回忆一下数据库较原始的JDBC是怎么管理事务的: //仅
- 第一次在自己虚机上安装mysql 中间碰到很多问题 在这里记下来,分享一下。linux centOS 6mysql版本 mysql-5.7.
- 八皇后问题描述问题: 国际象棋棋盘是8 * 8的方格,每个方格里放一个棋子。皇后这种棋子可以攻击同一行或者同一列或者斜线(左上左下右上右下四
- 前言最近已经播完第一季的电视剧《雪中悍刀行》,从播放量就可以看出观众对于这部剧的期待,总播放量达到50亿,可让人遗憾的是,豆瓣评分只有5.7
- 我就废话不多说了,直接上代码吧!import pandas as pdimport numpy as npimport matplotlib
- python遍历字符串中的每一个字符有4种方式:1. for in ;2.iter内置函数;3.内置函数range()或xrange();4
- 1、使用while循环实现输出2 - 3 + 4 - 5 + 6 ... + 100的和#方法一#从2开始计算i = 2#定义一个变量用于保
- 代码如下# -*- coding = utf-8 -*-# @time:2020/5/28/028 21:00# Author:cyx# @
- Python读取配置文件-ConfigParser二次封装直接上上代码test.conf[database]connect = mysqls