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表用来记

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值