以下是注意事项
只支持简单查询,例如select [属性] from [表] where [约束]。不支持连接查询
- 学生信息表名称--->studentdata
- 属性列:academy--->学院名
- 属性列:major--->专业名
- 属性列:class--->班级
- 属性列:sno--->学号
- 属性列:name--->姓名
小弟这学期的JSP&JAVA SERVLET课程上完了,课程作业是学生信息管理系统,在开发过程遇到了许多问题,记录下来,作为自己学习的总结,也可以给大家作为参考。如果有错误的地方,多多包涵。
github地址如下:
https://github.com/XiaoZhong233/StudentManagerSystem-JSP-
一、新建JAVA项目
File->New->DynamicWebProject
然后就是配置服务器,我用的是Tomcat,配置很简单,到官网下载好之后在项目新建中添加进去就可以了
二、引入Mysql的jar包
因为要用到数据库和服务端交互,因此要引入mysql的jar包,然后在项目中利用JDBC技术操作数据库就可以了
mysql的jar包在官网可以找到,我也上传到了百度网盘,分享给大家
https://pan.baidu.com/s/1YfucuLovNKBa4JMci1gfCg
然后在Java Resources中新建一个lib文件夹,把mysql的jar包粘贴到这里面;
右键,如上图一样选择Add to Build Path就可以了,为了保险起见,可以在WebContent的lib文件中也这样引入一个sql的jar包。
三、建立数据库连接工具
把项目构建好了,引入了需要用的jar包,我们就可以开始进行开发了。我们与服务端交互,首先就要有个工具,来打开与数据库的连接。话不多说,直接上代码
package javabean;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class ConnDB {
private static String URL = "jdbc:mysql://localhost:3306/"; //数据库连接 "student"是数据库名
private static String USER = "root";//数据库账号
private static String PASSWORD = "root";//数据库密码
private Connection conn = null;
/**
* 无参构造函数默认的数据库为student
*/
public ConnDB() {
try {
URL="jdbc:mysql://localhost:3306/student?characterEncoding=utf-8";
Class.forName("com.mysql.jdbc.Driver");
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
public ConnDB(String databaseName) {
try {
Class.forName("com.mysql.jdbc.Driver");
URL=URL+databaseName+"?characterEncoding=utf-8";
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
//获取数据库连接
public Connection getConnction() {
try {
conn = DriverManager.getConnection(URL, USER, PASSWORD);
} catch (SQLException e) {
e.printStackTrace();
}
return conn;
}
//关闭数据库连接
public void closeCon(Connection con) throws Exception{
if(con!=null){
con.close();
}
}
/**
* 根据传入的SQL语句返回一个结果集
*
* @param sql
* @return
* @throws Exception
*/
public ResultSet select(String sql) throws Exception {
Statement stmt = null;
ResultSet rs = null;
try {
stmt = conn.createStatement();
rs = stmt.executeQuery(sql);
return rs;
} catch (SQLException sqle) {
throw new SQLException("select data exception: "
+ sqle.getMessage());
} catch (Exception e) {
throw new Exception("System e exception: " + e.getMessage());
}
}
/**
* 根据传入的SQL语句向数据库增加一条记录
*
* @param sql
* @throws Exception
*/
public void insert(String sql) throws Exception {
PreparedStatement ps = null;
try {
ps = conn.prepareStatement(sql);
ps.executeUpdate();
} catch (SQLException sqle) {
throw new Exception("insert data exception: " + sqle.getMessage());
} finally {
try {
if (ps != null) {
ps.close();
}
} catch (Exception e) {
throw new Exception("ps close exception: " + e.getMessage());
}
}
try {
if (conn != null) {
conn.close();
}
} catch (Exception e) {
throw new Exception("connection close exception: " + e.getMessage());
}
}
/**
* 根据传入的SQL语句更新数据库记录
*
* @param sql
* @throws Exception
*/
public void update(String sql) throws Exception {
PreparedStatement ps = null;
try {
ps = conn.prepareStatement(sql);
ps.executeUpdate();
} catch (SQLException sqle) {
throw new Exception("update exception: " + sqle.getMessage());
} finally {
try {
if (ps != null) {
ps.close();
}
} catch (Exception e) {
throw new Exception("ps close exception: " + e.getMessage());
}
}
try {
if (conn != null) {
conn.close();
}
} catch (Exception e) {
throw new Exception("connection close exception: " + e.getMessage());
}
}
/**
* 根据传入的SQL语句删除一条数据库记录
*
* @param sql
* @throws Exception
*/
public void delete(String sql) throws Exception {
PreparedStatement ps = null;
try {
ps = conn.prepareStatement(sql);
ps.executeUpdate();
} catch (SQLException sqle) {
throw new Exception("delete data exception: " + sqle.getMessage());
} finally {
try {
if (ps != null) {
ps.close();
}
} catch (Exception e) {
throw new Exception("ps close exception: " + e.getMessage());
}
}
try {
if (conn != null) {
conn.close();
}
} catch (Exception e) {
throw new Exception("connection close exception: " + e.getMessage());
}
}
public static void main(String[] args) {
ConnDB connDB=new ConnDB();
try {
Connection connection=connDB.getConnction();
System.out.println("连接成功");
Statement stmt=connection.createStatement();
ResultSet rs=stmt.executeQuery("select * from studentdata");
while(rs.next()){
System.out.println(rs.getString(1));
}
connDB.closeCon(connection);
} catch (Exception e) {
// TODO: handle exception
}
}
}
这里数据库连接的URL为jdbc:mysql://localhost:3306/ 其中localhost:3306为用户名和端口,用':'分隔,用navicat连接到sql后就可以查看(navicat是一个很好用的数据库可视化工具,大家可以去官网下载一个来用)
在navicat中可以看到我们的主机名为localhost,端口号为3306,OK,这就是我们要在jdbc:mysql://后面加的东西。大家可以看到我写了两个构造函数,一个无参,默认连接到student这个库,另一个需要一个String指定数据库名。
拿默认连接来说,也就是student这个库,完整URL为:jdbc:mysql://localhost:3306/student?characterEncoding=utf-8 这里需要注意的是:如果我用jdbc:mysql://localhost:3306/student也是可以连接的上数据库的,但是在JDBC写入数据库的时候,会出现写入的值如果是中文,则会在数据库中乱码,所以我们可以在jdbc:mysql://localhost:3306/student加上?characterEncoding=utf-8指定我们写入时候的编码。
大家在写完这个工具的时候可以在main中测试下,是否连接成功
这样,我们的数据库连接工具就写好了。
四、接下来就是jsp网页了
我先把实现的成果图贴出来
注册成功
然后数据库中就会多出注册的信息(这里我新建了一个user表用来记录用户名和密码)
密码错误或用户未进行注册时会提醒,并且重新返回登录界面
登录成功后,直接进入学生信息管理系统界面,这里可以看到所有学生的信息(各位同学看到不要打我)
添加成功后:
系统会倒数,然后自动跳转至信息页面
在删除前,系统会弹窗和用户再一次确认是否删除信息,以防误删
删除成功后
可以看到,刚才新增的记录已经被删除了
点击修改按钮,即可进入修改页面,修改页面会自动填充好要修改学生的信息,用户只需要少许的改动即可修改信息
e.g.把姓名修改成“陈思成已被修改”
更改后的学生信息
查询功能分为按学号查找,按姓名查找,按SQL语句查找
界面做的很简单,只是用来练习,没必要花大精力在界面上
l 按学号查找
l 按姓名查找
l 按SQL语句查找
例如,要查找地信2班的学生的学院,专业,名字信息,SQL语句如下图所示
查询结果如下图所示
系统自动对未加入查询的属性列赋null值
好了,这就是我们要实现的功能,下面就来看代码吧,新建若干个jsp文件
项目代码结构:
每个页面的功能,我已经标注出来了,名字也能看出来哈哈。。
接下来又是贴代码
Login_deal.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
学生管理系统登录页
学生信息管理系统
要注意的是,要把开头三个charset都改成UTF-8,这样才能在JSP中使用中文
这里用了一个脚本来验证用户名密码是否非空。
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
注册管理员
管理员注册页面
<%@page import="javabean.ConnDB"%>
<%@page import="java.sql.*"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%request.setCharacterEncoding("UTF-8"); %>
注册结果
<%
try
{
ConnDB db=new ConnDB();
Connection connection=db.getConnction();
String sql="insert into user values("+user.getUsername()+","+user.getPassword()+")";
db.insert(sql);
out.print("");
}
catch(Exception e){
e.printStackTrace();
out.print("");
}
%>
@charset "UTF-8";
body{
padding:0px;
margin:0px;
font-size:12px;
}
body a{
color:#03515d;
text-decoration:none;
}
body button{
color:#03515d;
}
body span{
color:#03515d;
}
.center_bottom input{
color:#03515d;
font-size:12px;
height:20px;
width:40px;
padding:2px;
vertical-align:middle;
text-align:center;
margin-bottom:6px;
}
/**************************布局部分********************/
.table_div{
width:1000px;
padding:10px;
margin:0 auto;
}
.div_clear{
clear:both;
}
.left_top{
background:url("./tab/images/leftbottom.gif");
height:30px;
width:12px;
float:left;
}
.left_center{
background:url("./tab/images/rfcenter.gif");
height:530px;
width:12px;
float:left;
}
.left_bottom{
background:url("./tab/images/leftbottom.gif");
height:35px;
width:12px;
float:left;
}
.center_top{
background:url("./tab/images/center.gif") repeat-x;
height:30px;
line-height:30px;
width:900px;
float:left;
}
.center_center{
height:400px;
width:900px;
float:left;
}
.center_bottom{
background:url("./tab/images/center.gif") repeat-x;
height:35px;
width:900px;
float:left;
line-height:35px;
}
.right_top{
background:url("./tab/images/leftbottom.gif");
height:30px;
width:15px;
float:left;
}
.right_center{
background:url("./tab/images/rfcenter.gif");
height:530px;
width:15px;
float:left;
}
.right_bottom{
background:url("./tab/images/leftbottom.gif");
height:35px;
width:15px;
float:left;
}
/**************************************表格内容***********************************/
.table_content{
margin:5px;
border:1px solid #B5D6E6;
width:890px;
height:520px;
overflow-x:hidden;
overflow-y:auto;
}
.table_content table{
width:100%;
border:0;
border-collapse:collapse;
font-size:12px;
}
.table_content table tr:hover{
background-color:#C1EBFF;
}
.table_content table th{
border-collapse:collapse;
height:22px;
background:url("./tab/images/bg.gif");
border-right:1px solid #B5D6E6;
border-bottom:1px solid #B5D6E6;
}
.table_content table td{
height:22px;
word-wrap:break-word;
max-width:200px;
text-align:center;
vertical-align:middle;
border-right:1px solid #B5D6E6;
border-bottom:1px solid #B5D6E6;
}
<%@page import="java.sql.ResultSet"%>
<%@page import="java.sql.Connection"%>
<%@page import="javabean.ConnDB"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%request.setCharacterEncoding("UTF-8"); %>
学生信息查询结果
<%
ConnDB connDB=new ConnDB();
Connection connection=connDB.getConnction();
String sql="select * from studentdata";
ResultSet rs=connDB.select(sql);
%>
学生信息:
下面的表格就是查询结果:
学院名称
专 业
班 级
学 号
姓 名
操作
<%
int count=0;
while(rs.next()){
out.print("");
out.print("" + rs.getString(1).toString()+ " ");
out.print("" + rs.getString(2).toString() + " ");
out.print("" + rs.getString(3).toString() + " ");
out.print("" + rs.getString(4).toString() + " ");
out.print("" + rs.getString(5).toString() + " ");
out.print("
删除");
out.print("
编辑 ");
out.print(" ");
count++;
}
%>
共有<%=count %>条记录,当前第 1/1 页
跳转到
<%
if (rs != null) {
rs.close();
}
%>
这里就从数据库读取数据,然后输出成表格
Insert.jsp(增加学生记录页)
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
添加学生信息记录
添加学生信息记录
<%@page import="javabean.ConnDB"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%request.setCharacterEncoding("UTF-8"); %>
学生信息添加页
<%
String academy=request.getParameter("academy");
String major=request.getParameter("major");
String classs=request.getParameter("classs");
String sno=request.getParameter("sno");
String name=request.getParameter("name");
try{
ConnDB db=new ConnDB();
db.getConnction();
//String sql="insert into studentdata values('"+academy+"','"+major+"','"+classs+"','"+sno+"','"+name+"')";
String sql=String.format("insert into studentdata (academy,major,class,sno,name)"+
"values('%s','%s','%s','%s','%s')",academy,major,classs,sno,name);
System.out.println(sql);
db.insert(sql);
out.print(" ");
String jsscript=" ";
out.print(jsscript);
}
catch(Exception e){
e.printStackTrace();
out.print(" ");
String jsscript=" ";
out.print(jsscript);
}
%>
<%@page import="java.sql.*"%>
<%@page import="javabean.ConnDB"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
更新学生信息
<%
ConnDB db=new ConnDB();
db.getConnction();
String id=request.getParameter("id");
String sql="select * from studentdata where id='"+id+ "'";
ResultSet rs=db.select(sql);
rs.next();
%>
修改学生信息页
<%@page import="javabean.ConnDB"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%request.setCharacterEncoding("UTF-8"); %>
更新学生信息
<%
String academy=request.getParameter("academy");
String major=request.getParameter("major");
String classs=request.getParameter("classs");
String sno=request.getParameter("sno");
String name=request.getParameter("name");
int id=Integer.parseInt(request.getParameter("id"));
System.out.println(id);
System.out.println(academy);
System.out.println(major);
System.out.println(classs);
System.out.println(sno);
System.out.println(name);
ConnDB db=new ConnDB();
db.getConnction();
String sql="update studentdata set academy='"+academy+"', major='"+major+"',class='"+classs+"',sno='"+sno+"',name='"+name+"' where id="+id;
try{
db.update(sql);
out.print(" ");
String jsscript=" ";
out.print(jsscript);
}
catch(Exception e){
e.printStackTrace();
out.print("");
out.print(" ");
String jsscript=" ";
out.print(jsscript);
}
%>
成功修改数据!
查看当前数据库数据
<%@page import="javabean.ConnDB"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%request.setCharacterEncoding("UTF-8"); %>
学生信息删除页面
<%
try
{
ConnDB db=new ConnDB();
db.getConnction();
String id=request.getParameter("id");
System.out.println(id);
String sql_delete="delete from studentdata where id= '" +id+"'";
db.delete(sql_delete);
out.print(" ");
String jsscript=" ";
out.print(jsscript);
}
catch(Exception e){
e.printStackTrace();
out.print("");
out.print(" ");
String jsscript=" ";
out.print(jsscript);
}
%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
选择查询方式
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
学生信息查询
请输入学号,进行查询
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
学生信息查询
请输入姓名,进行查询
<%@page import="java.sql.ResultSet"%>
<%@page import="java.sql.Connection"%>
<%@page import="javabean.ConnDB"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%request.setCharacterEncoding("UTF-8"); %>
学生信息查询结果
<%
String name=request.getParameter("name");
ConnDB connDB=new ConnDB();
Connection connection=connDB.getConnction();
String sql="select * from studentdata where name='"+name+"'";
ResultSet rs=null;
try{
rs=connDB.select(sql);
}catch(Exception e){
e.printStackTrace();
out.print("");
out.print("window.location='query.jsp'");
}
%>
学生信息:
下面的表格就是查询结果:
学院名称
专 业
班 级
学 号
姓 名
操作
<%
int count=0;
if(!rs.next()){
out.print("");
out.print("");
out.print(" ");
String jsscript=" ";
out.print(jsscript);
out.print(" ");
out.print(" ");
}
else{
rs.beforeFirst();
while(rs.next()){
out.print("");
out.print("" + rs.getString(1).toString()+ " ");
out.print("" + rs.getString(2).toString() + " ");
out.print("" + rs.getString(3).toString() + " ");
out.print("" + rs.getString(4).toString() + " ");
out.print("" + rs.getString(5).toString() + " ");
out.print("
删除");
out.print("
编辑 ");
out.print(" ");
count++;
}
}
%>
共有<%=count %>条记录,当前第 1/1 页
跳转到
<%
if (rs != null) {
rs.close();
}
%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
学生信息查询
使用SQL查询语句进行查找
以下是注意事项
只支持简单查询,例如select [属性] from [表] where [约束]。不支持连接查询
- 学生信息表名称--->studentdata
- 属性列:academy--->学院名
- 属性列:major--->专业名
- 属性列:class--->班级
- 属性列:sno--->学号
- 属性列:name--->姓名
<%@page import="java.util.*"%>
<%@page import="java.sql.ResultSetMetaData"%>
<%@page import="java.sql.ResultSet"%>
<%@page import="java.sql.Connection"%>
<%@page import="javabean.ConnDB"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%request.setCharacterEncoding("UTF-8"); %>
学生信息查询结果
<%
String sql=request.getParameter("sql");
ConnDB connDB=new ConnDB();
Connection connection=connDB.getConnction();
ResultSet rs=null;
try{
rs=connDB.select(sql);
}catch(Exception e){
e.printStackTrace();
out.print("");
out.print("window.location='query.jsp'");
}
%>
学生信息:
下面的表格就是查询结果:
学院名称
专 业
班 级
学 号
姓 名
操作
<%
int count=0;
if(!rs.next()){
out.print("");
out.print("");
out.print(" ");
String jsscript=" ";
out.print(jsscript);
out.print(" ");
out.print(" ");
}
else{
rs.beforeFirst();
//获取列数
ResultSetMetaData resultSetMetaData=rs.getMetaData();
int numColumn=resultSetMetaData.getColumnCount();
int i;
List name=new ArrayList();
String columnName;
//定义开关,true的位置说明是有数据的
boolean[] switchs=new boolean[]{false,false,false,false,false,false};
for(i=1;i<=numColumn;i++){
columnName=resultSetMetaData.getColumnName(i);
System.out.println(columnName);
switch(columnName){
case "academy":
switchs[0]=true;
break;
case "major":
switchs[1]=true;
break;
case "class":
switchs[2]=true;
break;
case "sno":
switchs[3]=true;
break;
case "name":
switchs[4]=true;
break;
case "id":
break;
default:
break;
}
}
//定义rs的列数
int rsColumn;
while(rs.next()){
//i确定位置,rsColumn确定数据在rs中的位置
i=1;
rsColumn=0;
out.print("");
for(;i<=6;i++){
if(switchs[i-1]){
if(rsColumn<=numColumn)
{
rsColumn++;
}
out.print("" + rs.getString(rsColumn).toString()+ " ");
}
else{
if(i!=6){
out.print("" +"null"+ " ");
}
else{
out.print("" +"暂不支持操作"+ " ");
}
}
}
out.print(" ");
count++;
}
}
%>
共有<%=count %>条记录,当前第 1/1 页
跳转到
<%
if (rs != null) {
rs.close();
}
%>