jsp 按照学号查找学生_JSP&Servlet牛刀小试:学生信息管理系统

小弟这学期的JSP&JAVA SERVLET课程上完了,课程作业是学生信息管理系统,在开发过程遇到了许多问题,记录下来,作为自己学习的总结,也可以给大家作为参考。如果有错误的地方,多多包涵。

github地址如下:

一、新建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

pageEncoding="UTF-8"%>

学生管理系统登录页

function check(){

var username=document.getElementById("username");

var password=document.getElementById("password");

if(username.value==""||password.value==""){

alert("用户名或密码不可为空!");

return false;

}

return true;

}

function regist(){

//跳转至注册页

window.location='register.jsp';

}

学生信息管理系统

用户名:
密码:

要注意的是,要把开头三个charset都改成UTF-8,这样才能在JSP中使用中文

这里用了一个脚本来验证用户名密码是否非空。

Register.jsp(注册页面)

pageEncoding="UTF-8"%>

注册管理员

管理员注册页面

用户名:
密码:

Register_done.jsp(注册处理页面)

pageEncoding="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("");

}

%>

Table.css(css文件,用于控制表格布局)

@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;

}

studentInfo.jsp(学生信息管理页)

pageEncoding="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++;

}

%>

  共有条记录,当前第 1/1 页

跳转到

if (rs != null) {

rs.close();

}

%>

这里就从数据库读取数据,然后输出成表格

Insert.jsp(增加学生记录页)

pageEncoding="UTF-8"%>

function check(form){

if (form.academy.value == "") {

alert("学院名称不能为空");

return false;

}

if (form.major.value == "") {

alert("专业不能为空");

return false;

}

if (form.classs.value == "") {

alert("班级不能为空");

return false;

}

if (form.name.value == "") {

alert("姓名不能为空");

return false;

}

//验证数字的正则表达式

if (form.sno.value == "") {

alert("学号不能为空");

return false;

}

else

{

var reg=/^\d+$/;

var number=form.sno.value;

if(number.match(reg)){

}

else

{

alert("学号必须为纯数字");

return false;

}

}

return true;

}

添加学生信息记录

添加学生信息记录

学院名称:
专 业:
班 级:
学 号:
姓 名:

InsertDeal.jsp(添加学生信息处理页)

pageEncoding="UTF-8"%>

function countDown(secs,surl){

var jumpTo = document.getElementById('jumpTo');

jumpTo.innerHTML=""+secs+"";

if(--secs>0){

setTimeout("countDown("+secs+",'"+surl+"')",1000);

}

else{

location.href=surl;

-ma

}

}

学生信息添加页

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);

}

%>

Update.jsp(信息更新页)

pageEncoding="UTF-8"%>

更新学生信息

function check(form) {

if (form.academy.value == "") {

alert("学院名称不能为空");

return false;

}

if (form.major.value == "") {

alert("专业不能为空");

return false;

}

if (form.classs.value == "") {

alert("班级不能为空");

return false;

}

if (form.name.value == "") {

alert("姓名不能为空");

return false;

}

if (form.sno.value == "") {

alert("学号不能为空");

return false;

}

else

{

var reg=/^\d+$/;

var number=form.sno.value;

if(number.match(reg)){

}

else

{

alert("学号必须为纯数字");

return false;

}

}

return true;

}

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();

%>

修改学生信息页

学院名称:/>
专 业:/>
班 级:/>
学 号:/>
姓 名:/>

/>

if(rs!=null){

rs.close();

}

%>

UpdateDeal.jsp(信息更新处理页)

pageEncoding="UTF-8"%>

更新学生信息

function countDown(secs,surl){

var jumpTo = document.getElementById('jumpTo');

jumpTo.innerHTML=""+secs+"";

if(--secs>0){

setTimeout("countDown("+secs+",'"+surl+"')",1000);

}

else{

location.href=surl;

-ma

}

}

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);

}

%>

成功修改数据!

查看当前数据库数据

Delete.jsp(删除信息页面)

pageEncoding="UTF-8"%>

学生信息删除页面

function countDown(secs,surl){

var jumpTo = document.getElementById('jumpTo');

jumpTo.innerHTML=""+secs+"";

if(--secs>0){

setTimeout("countDown("+secs+",'"+surl+"')",1000);

}

else{

location.href=surl;

-ma

}

}

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);

}

%>

Query.jsp(查询页面)

pageEncoding="UTF-8"%>

选择查询方式

function byxuehao(){

window.location='queryByXueHao.jsp';

}

function byxingming(){

window.location='queryByXingMing.jsp';

}

function bysql(){

window.location='queryBySQL.jsp';

}

queryByXueHao.jsp(按学号查询页面)

pageEncoding="UTF-8"%>

function check(form) {

if (form.xuehao.value == "") {

alert("学号不能为空");

return false;

}

else

{

var reg=/^\d+$/;

var number=form.xuehao.value;

if(number.match(reg)){

}

else

{

alert("学号必须为纯数字");

return false;

}

}

return true;

}

学生信息查询

请输入学号,进行查询

学号:

QueryByXingMing.jsp(按姓名查询)

pageEncoding="UTF-8"%>

学生信息查询

请输入姓名,进行查询

姓名:

QueryByXingMingDone.jsp(姓名查询界面)

pageEncoding="UTF-8"%>

function countDown(secs,surl){

var jumpTo = document.getElementById('jumpTo');

jumpTo.innerHTML=""+secs+"";

if(--secs>0){

setTimeout("countDown("+secs+",'"+surl+"')",1000);

}

else{

location.href=surl;

-ma

}

}

学生信息查询结果

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("

查询失败:未查询到该学生记录"+

"8秒后系统会自动跳转,也可点击本处直接跳转重新查询 "+

"

");

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++;

}

}

%>

  共有条记录,当前第 1/1 页

跳转到

if (rs != null) {

rs.close();

}

%>

QueryBySQL.jsp(按照SQL语句进行查询)

pageEncoding="UTF-8"%>

学生信息查询

.main{

text-align: center; /*让div内部文字居中*/

background-color: #fff;

opacity:1;

border-radius: 20px;

width: 50%;

height: 370px;

margin: auto;

position: relative;

top: 0;

left: 0;

right: 0;

bottom: 0;

border: 2px solid black;

}

.leftDiv{

text-align: left; /*让div内部文字居中*/

width: 100%;

height: 100%;

left:0;

opacity:1;

top:27%;

position: absolute;

float:left;

}

function check(form){

var text = document.getElementById('sql').value.length;

if(text==0){

alert("SQL语句不可为空");

return false;

}

return true;

}

使用SQL查询语句进行查找

SQL语句: 
以下是注意事项

只支持简单查询,例如select [属性] from [表] where [约束]。不支持连接查询

  • 学生信息表名称--->studentdata
  • 属性列:academy--->学院名
  • 属性列:major--->专业名
  • 属性列:class--->班级
  • 属性列:sno--->学号
  • 属性列:name--->姓名

QueryBySQLDone.jsp(按SQL语句查询结果)

pageEncoding="UTF-8"%>

function countDown(secs,surl){

var jumpTo = document.getElementById('jumpTo');

jumpTo.innerHTML=""+secs+"";

if(--secs>0){

setTimeout("countDown("+secs+",'"+surl+"')",1000);

}

else{

location.href=surl;

-ma

}

}

学生信息查询结果

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("

查询失败:未查询到该学生记录"+

"8秒后系统会自动跳转,也可点击本处直接跳转重新查询 "+

"

");

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++;

}

}

%>

  共有条记录,当前第 1/1 页

跳转到

if (rs != null) {

rs.close();

}

%>


版权声明:本文为weixin_39759155原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。