使用displaytag实现数据库分页 (displaytag 数据库分页)

在软件开发中,经常需要对数据库进行分页操作,以便在页面上显示较大数据集的一部分,这样可以提高页面加载速度,并且也有助于减轻服务器的压力。 displaytag是一种在Java应用程序中实现分页显示数据的流行工具。在本文中,我们将介绍如何使用displaytag来实现数据库分页。

步骤1:使用Eclipse创建Java Web应用程序

我们需要创建一个Java Web应用程序,在Eclipse中可以轻松实现。在Eclipse菜单中选择File -> New -> Other -> Web -> Dynamic Web Project,然后提供一个项目名称和目标运行时环境(比如Tomcat),单击下一步。

在项目设置对话框中,选择Target Runtime(如Apache Tomcat v9.0),并选择Dynamic web module版本(如4.0),接着点击下一步。

在Web module设置对话框中,设置上下文根(这是Web应用程序在Tomcat中URL地址)及页面存储目录。单击完成,我们已成功创建了Java Web应用程序。

步骤2:连接到数据库

为了,我们需要先连接到数据库。在我们的示例代码中,我们将连接到MySQL数据库。因此,我们需要在Web应用程序中的lib目录中添加MySQL数据库连接器(mysql-connector-java-8.0.11.jar或更高版本)。然后,我们需要在项目的web.xml文件中添加以下配置:

“`

DB Connection

jdbc/dbconn

javax.sql.DataSource

Contner

DB Connection

jdbc/dbconn

javax.sql.DataSource

“`

接下来,我们就需要在Tomcat的conf目录的context.xml文件中添加以下代码:

“`

auth=”Contner”

type=”javax.sql.DataSource”

username=”USERNAME”

password=”PASSWORD”

driverClassName=”com.mysql.jdbc.Driver”

url=”jdbc:mysql://localhost:3306/DBNAME”/>

“`

在这里,我们需要将USERNAME和PASSWORD替换为数据库的用户名和密码,同时将DBNAME替换为数据库名称。

步骤3:创建数据库表并添加数据

在我们的示例代码中,我们将创建一个表,名称为movies,表结构如下:

“`

CREATE TABLE movies (

id INT NOT NULL AUTO_INCREMENT,

title VARCHAR(255) NOT NULL,

director VARCHAR(255) NOT NULL,

release_year INT NOT NULL,

PRIMARY KEY (id)

);

“`

接着,我们将添加一些测试数据:

“`

INSERT INTO movies (title, director, release_year) VALUES (“The Shawshank Redemption”, “Frank Darabont”, 1994);

INSERT INTO movies (title, director, release_year) VALUES (“The Godfather”, “Francis Ford Coppola”, 1972);

INSERT INTO movies (title, director, release_year) VALUES (“The Godfather: Part II”, “Francis Ford Coppola”, 1974);

INSERT INTO movies (title, director, release_year) VALUES (“The Dark Knight”, “Christopher Nolan”, 2023);

INSERT INTO movies (title, director, release_year) VALUES (“12 Angry Men”, “Sidney Lumet”, 1957);

INSERT INTO movies (title, director, release_year) VALUES (“Schindler’s List”, “Steven Spielberg”, 1993);

INSERT INTO movies (title, director, release_year) VALUES (“Pulp Fiction”, “Quentin Tarantino”, 1994);

INSERT INTO movies (title, director, release_year) VALUES (“The Lord of the Rings: The Fellowship of the Ring”, “Peter Jackson”, 2023);

INSERT INTO movies (title, director, release_year) VALUES (“Forrest Gump”, “Robert Zemeckis”, 1994);

INSERT INTO movies (title, director, release_year) VALUES (“The Empire Strikes Back”, “Irvin Kershner”, 1980);

INSERT INTO movies (title, director, release_year) VALUES (“The Matrix”, “The Wachowski Brothers”, 1999);

“`

步骤4:创建Movie实体类

为了将数据库表中的数据显示在Web应用程序中,我们需要创建Movie实体类。该类的代码如下:

“`

public class Movie {

private int id;

private String title;

private String director;

private int releaseYear;

public int getId() {

return id;

}

public void setId(int id) {

this.id = id;

}

public String getTitle() {

return title;

}

public void setTitle(String title) {

this.title = title;

}

public String getDirector() {

return director;

}

public void setDirector(String director) {

this.director = director;

}

public int getReleaseYear() {

return releaseYear;

}

public void setReleaseYear(int releaseYear) {

this.releaseYear = releaseYear;

}

}

“`

步骤5:编写MovieDao类

接下来,我们需要创建一个MovieDao类,该类用于从数据库中获取Movie实例。类的代码如下:

“`

public class MovieDao {

private Connection con;

public MovieDao() {

try {

Context ctx = new InitialContext();

DataSource ds = (DataSource) ctx.lookup(“java:/comp/env/jdbc/dbconn”);

con = ds.getConnection();

}

catch (NamingException | SQLException e) {

e.printStackTrace();

}

}

public List getMovies(int startIndex, int length) throws SQLException {

List list = new ArrayList();

String sql = “SELECT * FROM movies LIMIT ?, ?”;

PreparedStatement stmt = con.prepareStatement(sql);

stmt.setInt(1, startIndex);

stmt.setInt(2, length);

ResultSet rs = stmt.executeQuery();

while (rs.next()) {

Movie m = new Movie();

m.setId(rs.getInt(“id”));

m.setTitle(rs.getString(“title”));

m.setDirector(rs.getString(“director”));

m.setReleaseYear(rs.getInt(“release_year”));

list.add(m);

}

rs.close();

stmt.close();

return list;

}

public int getMoviesCount() throws SQLException {

String sql = “SELECT COUNT(*) FROM movies”;

Statement stmt = con.createStatement();

ResultSet rs = stmt.executeQuery(sql);

rs.next();

int count = rs.getInt(1);

rs.close();

stmt.close();

return count;

}

}

“`

在这个类中,我们首先通过JNDI连接到我们的MySQL数据库。然后,我们编写getMovies和getMoviesCount方法,用于从movies表中获取电影数据和电影数量数据。

步骤6:编写Movies.jsp页面

我们需要编写Movies.jsp页面,并使用displaytag来实现数据库分页。页面的代码如下:

“`

List of Movies

List of Movies

<%

try {

int currentPage = request.getParameter(“page”) != null ? Integer.parseInt(request.getParameter(“page”)) : 1;

int startIndex = (currentPage – 1) * 5;

MovieDao dao = new MovieDao();

List movies = dao.getMovies(startIndex, 5);

int totalRows = dao.getMoviesCount();

pageContext.setAttribute(“movies”, movies);

pageContext.setAttribute(“totalRows”, totalRows);

}

catch (SQLException e) {

e.printStackTrace();

}

%>

“`

在这个页面中,我们首先导入了MovieDao和Movie实体类。然后,我们使用displaytag来显示movies表中的电影数据。我们设置了pagesize为5,表示每页显示5条数据。在表格之下,我们使用display:pagination来显示分页导航栏。

在页面上方,我们使用P脚本并调用MovieDao来获取电影数据。我们首先尝试从请求参数中获取当前页数,如果为空,则默认为之一页。我们设置startIndex为每页显示5条数据的起始索引。然后,我们调用MovieDao的getMovies和getMoviesCount方法,分别获取movies表中的电影数据和电影数量数据。我们使用pageContext.setAttribute方法将数据存储在pageContext中,以便在displaytag表格中使用。

结论

相关问题拓展阅读:

  • struts分页显示问题

struts分页显示问题

建议LZ换中仿隐思路,采用displayTag标签来实现吧

你可以先尝试下

这上面的小程序案例,你会发现displayTag标樱猜签很强备颂厅大…

把你的值方在request 或尘毁者session属性帆陪中 action里 用 getAttribute()方法

百度的分页派轿备就是问号传参的

displaytag 数据库分页的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于displaytag 数据库分页,使用displaytag实现数据库分页,struts分页显示问题的信息别忘了在本站进行查找喔。

香港服务器首选树叶云,2H2G首月10元开通。
树叶云(shuyeidc.com)提供简单好用,价格厚道的香港/美国云服务器和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/267219.html<

(0)
运维的头像运维
上一篇2025-05-06 07:51
下一篇 2025-05-06 07:53

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注