1.思维导图
2.导出,导入框架的mvc.jar
3.配置框架的相关配置文件
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1">
<display-name>J2ee13</display-name>
<servlet>
<servlet-name>mvc</servlet-name>
<servlet-class>com.tyf.framework.DispatchServlet</servlet-class>
<init-param>
<param-name>configurationLocation</param-name>
<param-value>/mvc.xml</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>mvc</servlet-name>
<url-pattern>*.action</url-pattern>
</servlet-mapping>
</web-app>
3.用mvc.jar包实现增删改 查
3.1通用增删改代码
/**
* 共用的方法用于执行sql语句实现增删改
*
* @param sql
* @return
*/
public int executeUpdate(String sql) {
Connection con = null;
PreparedStatement ps = null;
ResultSet rs = null;
int n = 0;
try {
con = DBAccess.getConnection();
ps = con.prepareStatement(sql);
n = ps.executeUpdate();
} catch (Exception e) {
e.printStackTrace();
} finally {
DBAccess.close(con, ps, rs);
}
return n;
}
3.2通用分页代码
public interface CallBack<T>{
public List<T> forEach(ResultSet rs) throws Exception;
}
/**
* 1.通用分页两个基本要素
* 1.1 需要知道满足条件的条目数
* 1.2 查询满足条件指定页码的结果
* @throws Exception
*/
public List<T> executeQuery(PageBean pb, String sql,CallBack<T> cb) throws Exception {
Connection con = null;
PreparedStatement ps = null;
ResultSet rs = null;
try {
con = DBAccess.getConnection();
// 如果用户需要分页 就将用户传递过来sql语句进行转换
if (null != pb && pb.isPagination()) {
String countSql = this.countSql(sql);
ps = con.prepareStatement(countSql);
rs = ps.executeQuery();
if (rs.next()) {
pb.setTotal(rs.getInt(1));
}
// 开始查询结果
String pageSql = this.pageSql(sql, pb);
ps = con.prepareStatement(pageSql);
} else {
// 用户不需要分页
ps = con.prepareStatement(sql);
}
rs = ps.executeQuery();
} catch (Exception e) {
e.printStackTrace();
}
return cb.forEach(rs);
}
3.3调用通用方法实现增删改 查
package com.tyf.web;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.tyf.dao.BookDao;
import com.tyf.entity.Book;
import com.tyf.framework.ActionSupport;
import com.tyf.framework.ModelDriver;
import com.zking.utli.PageBean;
public class BookAction extends ActionSupport implements ModelDriver<Book>{
private Book book = new Book();
private BookDao db =new BookDao();
@Override
public Book getModel() {
return book;
}
public String add(HttpServletRequest req, HttpServletResponse resp) {
try {
db.add(book);
} catch (Exception e) {
e.printStackTrace();
}
return "toList";
}
public String delete(HttpServletRequest req, HttpServletResponse resp) {
try {
db.delete(book);
} catch (Exception e) {
e.printStackTrace();
}
return "toList";
}
public String edit(HttpServletRequest req, HttpServletResponse resp) {
try {
db.edit(book);
} catch (Exception e) {
e.printStackTrace();
}
return "toList";
}
public String list(HttpServletRequest req, HttpServletResponse resp) {
PageBean pb =new PageBean();
pb.setRequest(req);
try {
List<Book> ls = db.list(book, pb);
req.setAttribute("books", ls);
req.setAttribute("pageBean", pb);
} catch (Exception e) {
e.printStackTrace();
}
return "list";
}
public String toEdit(HttpServletRequest req, HttpServletResponse resp) {
//如果跳转的新增界面无需查询,如果是跳转的是修改界面,需要查询当前bid对应的数据,回显到界面
if (book.getBid() != 0) {
try {
List<Book> ls = db.list(book , null);
req.setAttribute("b", ls.get(0));
} catch (Exception e) {
e.printStackTrace();
}
}
return "toEdit";
}
}
4.运行结果
修改前:
修改后: