5. 删除数据

在删除数据的时候,需要指定删除条件,否则会把数据库表中的数据全部删除。在JSP页面中获得删除条件以后,调用JDBC的删除条件,把数据库表中的数据删除。删除操作的JSP页面代码如下:

delete.jsp

<%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>
<%@ page import="java.sql.*" %>
<%@page import="java.sql.Connection"%>
<%@page import="java.sql.PreparedStatement"%>
<%@page import="java.sql.ResultSet"%>
<%@page import="java.sql.DriverManager"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>"> <title>My JSP 'delete.jsp' starting page</title> <meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
--> </head> <body>
<form action="" method="post">
<label>请输入要删除的部门id:</label><br/><br/>
<input type="text" name="d_id"/><br/><br/>
<input type="submit" value="删除"/>
</form>
</body>
<%
Connection con = null;
PreparedStatement ps = null;
// ResultSet rs = null;
try{
int d_id = 0;
d_id = Integer.parseInt(request.getParameter("d_id"));
Class.forName("com.mysql.jdbc.Driver");
System.out.println("数据库驱动创建成功!");
con = DriverManager.getConnection("jdbc:mysql://localhost:3306/bank","root","1234");
System.out.println("数据库连接成功!");
String sql = "delete from dept where d_id=?";
ps = con.prepareStatement(sql);
ps.setInt(1,d_id);
ps.executeUpdate();
out.println("删除成功!");
}catch (Exception e){
e.printStackTrace();
}
%>
</html>

程序运行界面如下:

6. 分页显示

当数据量很多的时候,一页显示不完,这个时候就需要用到分页显示。分页显示数据的时候,如果当前的页是第一页,【上一页】超链接是不可单击状态;如果当前页是最后一页,【下一页】超链接是不可单击状态。分页显示的所有代码都写在JSP文件中,代码如下:

showAllByPage.jsp

<%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ page import="com.cn.vo.*" %>
<%@ page import="java.sql.*" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>My JSP 'showAllByPage.jsp' starting page</title>
</head>
<%
ResultSet rs = null;
PreparedStatement pstmt =null;
Connection conn = null;
List<DeptVo> list = new ArrayList<DeptVo>();
try {
String page1 = request.getParameter("page");//获得页面传递过来的page值赋值给page1
int page2 =1;
if(page1 != null){
//如果页面传递过来的page值存在,则把该page1赋值给page2变量
page2 = Integer.parseInt(page1);
}
request.setAttribute("page2", page2);
Class.forName("com.mysql.jdbc.Driver" );//创建数据库驱动
//连接数据库
conn =
DriverManager.getConnection("jdbc:mysql://localhost:3306/bank","root","1234");
//分页查询的SQL语句,每页显示5条记录
String sql = "select * from dept order by id desc limit ?,5";
pstmt = conn.prepareStatement(sql);
pstmt.setInt(1, page2);
rs = pstmt.executeQuery();
while(rs.next()){
DeptVo deptVo = new DeptVo();
// 把各属性放入CarsVo对象中
deptVo.setId(rs.getString("id"));
deptVo.setAddress(rs.getString("address"));
deptVo.setD_name(rs.getString("d_name"));
deptVo.setEmpnumber(rs.getInt("empnumber"));
deptVo.setD_id(rs.getInt("d_id")); list.add(deptVo);//把CarsVo对象放入集合中
request.setAttribute("list", list);
}
int count =0;//声明一个count变量,用于存储记录数
int maxpage = 0;//声明一个maxpage变量,原来表示最大页数
Statement stmt = conn.createStatement();
String sql1 ="select count(*) from dept";//查询总记录数的SQL语句 rs = stmt.executeQuery(sql1); while (rs.next()) {
count = rs.getInt(1);//如果结果集存在,记录数初始化值为1
}
maxpage = (count+4)/5;//最大页数等于总记录条数加上4,再除以5
request.setAttribute("maxpage", maxpage);
} catch (SQLException e) {
e.printStackTrace();
}
%>
<body>
<table border="1" align="center" width="70%">
<tr>
<td>部门编号</td>
<td>部门地址</td>
<td>部门人数</td>
<td>部门名称</td>
<td>部门id</td>
</tr>
<c:forEach items="${list}" var="list">
<tr>
<td>${list.id }</td>
<td>${list.address }</td>
<td>${list.empnumber }</td>
<td>${list.d_name }</td>
<td>${list.d_id }</td>
</tr>
</c:forEach>
</table>
<div align="center"> <a href="?page=1">首页</a>
<c:if test="${page2 ==1}">上一页</c:if>
<c:if test="${page2 > 1}"><a href="?page=${page2 -1 }">上一页</a></c:if>
<c:if test="${page2 == maxpage}">下一页</c:if>
<c:if test="${page2 < maxpage}"><a href="?page=${page2 +1 }">下一页</a></c:if>
<a href="?page=${maxpage }">末页</a>
</div>
</body>
</html>

上述代码中,分页显示设置成每页显示5条记录,默认的页数为第一页,也就是说第一次访问时,看到的是第一页的数据,页面效果如下图所示:

JDBC结合JSP使用(2)的更多相关文章

  1. JDBC+Servlet+jsp(增删查改)

    先在mysql新增数据库和表先,把下面的几句代码复制去到mysql运行就可以创建成功了!  创建数据库 create database jdbc01 character set utf8 collat ...

  2. JDBC结合JSP使用(1)

    1. 添加数据 在jsp页面中添加数据,和在serv中添加数据相似.获得页面中提交的数据以后,把数据保存到数据库表中,JSP的代码如下: add.jsp <%@ page language=&q ...

  3. 实例: Java代码操作oracle数据库(JDBC+sevrlet+jsp+html)

    1, 注册页面 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Strict//EN" "http://www.w3.or ...

  4. JDBC+Servlet+JSP实现基本的增删改查(简易通讯录)

    前言: 最近学习JavaWeb的过程中,自己实践练手了几个小项目,目前已经上传到我的Github上https://github.com/Snailclimb/JavaWebProject.目前只上传了 ...

  5. 简单的员工管理系统(Mysql+jdbc+Servlet+JSP)

    员工管理系统 因为学业要求,需要完成一个过关检测,但是因为检测之前没有做好准备,且想到之前用mysql+jdbc+Struts2+bootstrap做成了一个ATM系统(主要有对数据的增删改查操作), ...

  6. jdbc+servlet+jsp实现登录验证

    基础知识准备:sql的增删改查. 新增:insert into 表名称(字段名.....)values(字段名....). 修改:update 表名称 set  字段名="新值" ...

  7. JDBC+Servlet+JSP的学生案例增删改查

    数据库信息传输到页面实现. 先进行学生信息页面展示: 接口IStudentDao public interface IStudentDao { /** * 保存操作 * @param stu 学生对象 ...

  8. JSP简单访问数据库

    Java代码 public class DBHelper { private String driverName; private String url; private String user; p ...

  9. Java web开发,在一个jsp里放太多java代码的后果,摘自 java web轻量级开发面试教程

    现要做一个简单的登录页面,如果用户通过验证,会显示Welcome用户名的欢迎词,反之则返回登录页面让用户再次输入 这部分的完整代码是JSPDemo项目里的login.jsp,下面来分析一下关键代码. ...

随机推荐

  1. atomikos + druid 连接超时失效

    atomikos + druid 连接超时失效,需要多次连接才能成功. 首次连接会报异常: 2018-01-08 16:58:12 DEBUG [com.jpcar.model.dao.jpcar.A ...

  2. eschop购物实现立即购买和加入购物车

    后台=>平台=>商店设置=>购物流程 是否一步购物设置为否 2:修改代码 .js/common.js function addToCartShowDivResponse(result ...

  3. 查看锁信息(开启InnoDB监控)

    当前mysql版本:5.6.21 一.背景 在mysql处理死锁问题时,由于show engine innodb status输出来的死锁日志无任务事务上下文,并不能很好地诊断相关事务所持有的所有锁信 ...

  4. type与instance区别

    class Foo(object): pass class Bar(Foo): pass obj = Bar() # isinstance用于判断,对象是否是指定类或其派生类的实例 print(isi ...

  5. navicat premium 的使用——navicat 连接MySQL数据库

    最近,在学习navicat premium这款第三方软件,他是一个三方数据库管理软件,在前一段时间实习的时候,我使用这款软件调用过服务器上的数据库,不过,当时并没有仔细研究,再次遇到这个软件,我决定仔 ...

  6. 洛谷.2619.[国家集训队2]Tree I(带权二分 Kruskal)

    题目链接 \(Description\) 给定一个无向带权连通图,每条边是黑色或白色.求一棵最小权的恰好有K条白边的生成树. \(Solution\) Kruskal是选取最小的n-1条边.而白边数有 ...

  7. C# 中判断字符串是否包含另一段字符串,请使用 Contains

    使用:Contains 比 IndexOf 的性能提高很多. 因为 Contains 是判断某个字符串是否在另外一个字符串中,而IndexOf需要返回下标值.

  8. 为什么Android手机总是越用越慢?

    根据第三方的调研数据显示,有77%的Android手机用户承认自己曾遭遇过手机变慢的影响,百度搜索“Android+卡慢”,也有超过460万条结果.在业内,Android手机一直有着“越用越慢”的口碑 ...

  9. 【洛谷】2607: [ZJOI2008]骑士【树形DP】【基环树】

    P2607 [ZJOI2008]骑士 题目描述 Z国的骑士团是一个很有势力的组织,帮会中汇聚了来自各地的精英.他们劫富济贫,惩恶扬善,受到社会各界的赞扬. 最近发生了一件可怕的事情,邪恶的Y国发动了一 ...

  10. Java发送HTTP POST请求示例

    概述: http请求在所有的编程语言中几乎都是支持的,我们常用的两种为:GET,POST请求.一般情况下,发送一个GET请求都很简单,因为参数直接放在请求的URL上,所以,对于PHP这种语言,甚至只需 ...