使用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
<%
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表格中使用。
结论