JDBC实现学生管理系统

 更新时间:2019年02月20日 10:42:15   作者:feidao0  
这篇文章主要为大家详细介绍了JDBC实现学生管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了JDBC实现学生管理系统的具体代码,供大家参考,具体内容如下

1、学生类

package manage;
 
import java.util.Date;
 
/**
 * @author fanxf
 * @since 2018/4/27 17:01
 */
public class Student {
 
 private int id;
 
 private int age;
 
 private String sex;
 
 private String name;
 
 private Date dateCreated;
 
 public int getId() {
  return id;
 }
 
 public void setId(int id) {
  this.id = id;
 }
 
 public int getAge() {
  return age;
 }
 
 public void setAge(int age) {
  this.age = age;
 }
 
 public String getSex() {
  return sex;
 }
 
 public void setSex(String sex) {
  this.sex = sex;
 }
 
 public String getName() {
  return name;
 }
 
 public void setName(String name) {
  this.name = name;
 }
 
 public Date getDateCreated() {
  return dateCreated;
 }
 
 public void setDateCreated(Date dateCreated) {
  this.dateCreated = dateCreated;
 }
 
 public Student() {
 }
 
 public Student(int age, String sex, String name) {
  this.age = age;
  this.sex = sex;
  this.name = name;
 }
 
 public Student(int id, int age, String sex, String name) {
  this.id = id;
  this.age = age;
  this.sex = sex;
  this.name = name;
 }
 
 @Override
 public String toString() {
  return "Student{" +
    "id=" + id +
    ", age=" + age +
    ", sex='" + sex + '\'' +
    ", name='" + name + '\'' +
    ", dateCreated=" + dateCreated +
    '}';
 }
}

2、jdbc工具类

package manage;
 
import java.io.IOException;
import java.sql.*;
import java.util.Properties;
 
/**
 * @author fanxf
 * @since 2018/4/27 11:06
 */
//数据库的工具类
public class JdbcUtils {
 
 private static String driver = "";
 private static String url = "";
 private static String user = "";
 private static String password = "";
 
 static {
  Properties p = new Properties();
  try {
   p.load(Thread.currentThread().getContextClassLoader().getResourceAsStream("db.properties"));
  } catch (IOException e) {
   e.printStackTrace();
  }
  driver = p.getProperty("driver");
  url = p.getProperty("url");
  user = p.getProperty("user");
  password = p.getProperty("password");
  try {
   Class.forName(driver);
  } catch (ClassNotFoundException e) {
   e.printStackTrace();
  }
 }
 
 public static Connection getConnection() {
  try {
   return DriverManager.getConnection(url, user, password);
  } catch (SQLException e) {
   e.printStackTrace();
  }
  return null;
 }
 //释放的时候要从小到大释放
 //Connection -> Statement --> Resultset
 
 
 public static void release(ResultSet rs, Statement stmt, Connection conn) {
  if (rs != null) {
   try {
    rs.close();
   } catch (SQLException e) {
    e.printStackTrace();
   }
  }
  if (stmt != null) {
   try {
    stmt.close();
   } catch (SQLException e) {
    e.printStackTrace();
   }
  }
 
  if (conn != null) {
   try {
    conn.close();
   } catch (SQLException e) {
    e.printStackTrace();
   }
  }
 }
}

3、代码

package manage;
 
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Scanner;
 
/**
 * @author fanxf
 * @since 2018/4/27 17:06
 */
public class ManageSystem {
 
 private static Connection conn = null;
 private static PreparedStatement ps = null;
 private static ResultSet rs = null;
 
 /**
  * 添加学生数据
  *
  * @param student
  * @return
  */
 public static int addStudent(Student student) {
  conn = JdbcUtils.getConnection();
  int result = 0;
  try {
   ps = conn.prepareStatement("INSERT INTO student (age, sex, `name`, dateCreated) VALUES (?, ?, ?, now())");
   ps.setInt(1, student.getAge()); //设置第一个参数
   ps.setString(2, student.getSex()); //设置第二个参数
   ps.setString(3, student.getName()); //设置第三个参数
   result = ps.executeUpdate();
  } catch (SQLException e) {
   e.printStackTrace();
  } finally {
   JdbcUtils.release(null, ps, conn); //关闭连接
  }
  return result;
 }
 
 public void add() {
  Scanner scan = new Scanner(System.in);
  System.out.println("请输入学生年龄");
  int age = scan.nextInt();
  System.out.println("请输入学生性别");
  String sex = scan.next();
  System.out.println("请输入学生姓名");
  String name = scan.next();
  Student s = new Student(age, sex, name);
  int flag = addStudent(s);
  if (flag > 0) {
   System.out.println("添加成功");
  } else {
   System.out.println("添加失败");
  }
 }
 
 /**
  * 修改
  *
  * @param student
  * @return
  */
 public static int updateStudent(Student student) {
  conn = JdbcUtils.getConnection();
  int result = 0;
  try {
   ps = conn.prepareStatement("UPDATE student SET age = ?, sex = ?, `name` = ? WHERE id = ?");
   ps.setInt(1, student.getAge()); //设置第一个参数
   ps.setString(2, student.getSex()); //设置第二个参数
   ps.setString(3, student.getName()); //设置第三个参数
   ps.setInt(4, student.getId());
   result = ps.executeUpdate();
  } catch (SQLException e) {
   e.printStackTrace();
  } finally {
   JdbcUtils.release(null, ps, conn); //关闭连接
  }
  return result;
 }
 
 public void update() {
  Scanner scan = new Scanner(System.in);
  System.out.println("请输入学生id");
  int id = scan.nextInt();
  System.out.println("请输入学生年龄");
  int age = scan.nextInt();
  System.out.println("请输入学生性别");
  String sex = scan.next();
  System.out.println("请输入学生姓名");
  String name = scan.next();
  Student s = new Student(id, age, sex, name);
  int flag = updateStudent(s);
  if (flag > 0) {
   System.out.println("更新成功");
  } else {
   System.out.println("更新失败");
  }
 }
 
 /**
  * 删除
  *
  * @param id
  * @return
  */
 public static int deleteStudent(int id) {
  conn = JdbcUtils.getConnection();
  int result = 0;
  try {
   ps = conn.prepareStatement("DELETE FROM student WHERE id = ?");
   ps.setInt(1, id); //设置第一个参数
   result = ps.executeUpdate();
  } catch (SQLException e) {
   e.printStackTrace();
  } finally {
   JdbcUtils.release(null, ps, conn); //关闭连接
  }
  return result;
 }
 
 public void delete() {
  Scanner scan = new Scanner(System.in);
  System.out.println("请输入学生id");
  int id = scan.nextInt();
  int flag = deleteStudent(id);
  if (flag > 0) {
   System.out.println("删除成功");
  } else {
   System.out.println("删除失败");
  }
 }
 
 public static void main(String[] args) {
  System.out.println("************ 欢迎进入学生管理系统 *************");
  ManageSystem ms = new ManageSystem();
  boolean b = true;
  while (b) {
   System.out.println("你想进行以下哪项操作");
   System.out.println("1、添加学生 2、更新学生数据 3、学生信息查询 4、删除学生 0、退出");
   Scanner scan = new Scanner(System.in);
   int i = scan.nextInt();
   switch (i) {
    case 1:
     ms.add();
     break;
    case 2:
     ms.update();
     break;
    case 3:
     System.out.println();
     break;
    case 4:
     ms.delete();
     break;
    default:
     System.out.println("没有该操作选项,请重新来过!");
     main(args);
     break;
   }
  }
 }
}

4、properties数据库文件自己配置

数据库字段根据学生类建立!

更多学习资料请关注专题《管理系统开发》。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Java深入浅出讲解String类常见方法

    Java深入浅出讲解String类常见方法

    在C语言中,如果要表示字符串而且对字符串进行操作的话,依靠的是数组和指针,而Java中提供了String类用来专门表示字符串,String类中常见的方法,以及一些细节是本篇重点
    2022-04-04
  • SpringBoot整合RocketMQ的详细过程

    SpringBoot整合RocketMQ的详细过程

    这篇文章主要介绍了SpringBoot整合RocketMQ的详细过程,本文分为三部分,第一部分实现SpringBoot与RocketMQ的整合,第二部分解决在使用RocketMQ过程中可能遇到的一些问题并解决他们,第三部分介绍如何封装RocketMQ以便更好地使用,需要的朋友可以参考下
    2023-04-04
  • Java 线程池ExecutorService详解及实例代码

    Java 线程池ExecutorService详解及实例代码

    这篇文章主要介绍了Java 线程池ExecutorService详解及实例代码的相关资料,线程池减少在创建和销毁线程上所花的时间以及系统资源的开销.如果不使用线程池,有可能造成系统创建大量线程而导致消耗系统内存以及”过度切换“
    2016-11-11
  • SpringBoot 自定义注解异步记录复杂日志详解

    SpringBoot 自定义注解异步记录复杂日志详解

    这篇文章主要为大家介绍了SpringBoot 自定义注解异步记录复杂日志详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • SpringMVC的Dispatcher解读

    SpringMVC的Dispatcher解读

    这篇文章主要介绍了SpringMVC的Dispatcher用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • 一篇文章带你详解Spring的概述

    一篇文章带你详解Spring的概述

    这篇文章主要为大家介绍了Spring的概述,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-01-01
  • mybatis中oracle实现分页效果实例代码

    mybatis中oracle实现分页效果实例代码

    实现分页的方式有很多,但常用的是通过SQL来显示分页。这篇文章主要介绍了mybatis中oracle实现分页效果实例代码,有兴趣的可以了解一下。
    2017-04-04
  • SpringBoot整合JDBC的实现

    SpringBoot整合JDBC的实现

    这篇文章主要介绍了SpringBoot整合JDBC的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • SpringBoot集成mybatis实例

    SpringBoot集成mybatis实例

    本篇文章主要介绍了SpringBoot集成mybatis实例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04
  • SpringBoot2.x 集成腾讯云短信的详细流程

    SpringBoot2.x 集成腾讯云短信的详细流程

    本文主要对SpringBoot2.x集成腾讯云短信进行简单总结,其中SpringBoot使用的2.4.5版本,本文通过业务流程图实例代码相结合给大家介绍的非常详细,需要的朋友参考下吧
    2021-06-06

最新评论