JDBC實(shí)現(xiàn)學(xué)生管理系統(tǒng)
本文實(shí)例為大家分享了JDBC實(shí)現(xiàn)學(xué)生管理系統(tǒng)的具體代碼,供大家參考,具體內(nèi)容如下
1、學(xué)生類(lèi)
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工具類(lèi)
package manage;
import java.io.IOException;
import java.sql.*;
import java.util.Properties;
/**
* @author fanxf
* @since 2018/4/27 11:06
*/
//數(shù)據(jù)庫(kù)的工具類(lèi)
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;
}
//釋放的時(shí)候要從小到大釋放
//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;
/**
* 添加學(xué)生數(shù)據(jù)
*
* @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()); //設(shè)置第一個(gè)參數(shù)
ps.setString(2, student.getSex()); //設(shè)置第二個(gè)參數(shù)
ps.setString(3, student.getName()); //設(shè)置第三個(gè)參數(shù)
result = ps.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
} finally {
JdbcUtils.release(null, ps, conn); //關(guān)閉連接
}
return result;
}
public void add() {
Scanner scan = new Scanner(System.in);
System.out.println("請(qǐng)輸入學(xué)生年齡");
int age = scan.nextInt();
System.out.println("請(qǐng)輸入學(xué)生性別");
String sex = scan.next();
System.out.println("請(qǐng)輸入學(xué)生姓名");
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()); //設(shè)置第一個(gè)參數(shù)
ps.setString(2, student.getSex()); //設(shè)置第二個(gè)參數(shù)
ps.setString(3, student.getName()); //設(shè)置第三個(gè)參數(shù)
ps.setInt(4, student.getId());
result = ps.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
} finally {
JdbcUtils.release(null, ps, conn); //關(guān)閉連接
}
return result;
}
public void update() {
Scanner scan = new Scanner(System.in);
System.out.println("請(qǐng)輸入學(xué)生id");
int id = scan.nextInt();
System.out.println("請(qǐng)輸入學(xué)生年齡");
int age = scan.nextInt();
System.out.println("請(qǐng)輸入學(xué)生性別");
String sex = scan.next();
System.out.println("請(qǐng)輸入學(xué)生姓名");
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); //設(shè)置第一個(gè)參數(shù)
result = ps.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
} finally {
JdbcUtils.release(null, ps, conn); //關(guān)閉連接
}
return result;
}
public void delete() {
Scanner scan = new Scanner(System.in);
System.out.println("請(qǐng)輸入學(xué)生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("************ 歡迎進(jìn)入學(xué)生管理系統(tǒng) *************");
ManageSystem ms = new ManageSystem();
boolean b = true;
while (b) {
System.out.println("你想進(jìn)行以下哪項(xiàng)操作");
System.out.println("1、添加學(xué)生 2、更新學(xué)生數(shù)據(jù) 3、學(xué)生信息查詢(xún) 4、刪除學(xué)生 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("沒(méi)有該操作選項(xiàng),請(qǐng)重新來(lái)過(guò)!");
main(args);
break;
}
}
}
}4、properties數(shù)據(jù)庫(kù)文件自己配置
數(shù)據(jù)庫(kù)字段根據(jù)學(xué)生類(lèi)建立!
更多學(xué)習(xí)資料請(qǐng)關(guān)注專(zhuān)題《管理系統(tǒng)開(kāi)發(fā)》。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java深入淺出講解String類(lèi)常見(jiàn)方法
在C語(yǔ)言中,如果要表示字符串而且對(duì)字符串進(jìn)行操作的話,依靠的是數(shù)組和指針,而Java中提供了String類(lèi)用來(lái)專(zhuān)門(mén)表示字符串,String類(lèi)中常見(jiàn)的方法,以及一些細(xì)節(jié)是本篇重點(diǎn)2022-04-04
SpringBoot整合RocketMQ的詳細(xì)過(guò)程
這篇文章主要介紹了SpringBoot整合RocketMQ的詳細(xì)過(guò)程,本文分為三部分,第一部分實(shí)現(xiàn)SpringBoot與RocketMQ的整合,第二部分解決在使用RocketMQ過(guò)程中可能遇到的一些問(wèn)題并解決他們,第三部分介紹如何封裝RocketMQ以便更好地使用,需要的朋友可以參考下2023-04-04
Java 線程池ExecutorService詳解及實(shí)例代碼
這篇文章主要介紹了Java 線程池ExecutorService詳解及實(shí)例代碼的相關(guān)資料,線程池減少在創(chuàng)建和銷(xiāo)毀線程上所花的時(shí)間以及系統(tǒng)資源的開(kāi)銷(xiāo).如果不使用線程池,有可能造成系統(tǒng)創(chuàng)建大量線程而導(dǎo)致消耗系統(tǒng)內(nèi)存以及”過(guò)度切換“2016-11-11
SpringBoot 自定義注解異步記錄復(fù)雜日志詳解
這篇文章主要為大家介紹了SpringBoot 自定義注解異步記錄復(fù)雜日志詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
mybatis中oracle實(shí)現(xiàn)分頁(yè)效果實(shí)例代碼
實(shí)現(xiàn)分頁(yè)的方式有很多,但常用的是通過(guò)SQL來(lái)顯示分頁(yè)。這篇文章主要介紹了mybatis中oracle實(shí)現(xiàn)分頁(yè)效果實(shí)例代碼,有興趣的可以了解一下。2017-04-04
SpringBoot整合JDBC的實(shí)現(xiàn)
這篇文章主要介紹了SpringBoot整合JDBC的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01
SpringBoot2.x 集成騰訊云短信的詳細(xì)流程
本文主要對(duì)SpringBoot2.x集成騰訊云短信進(jìn)行簡(jiǎn)單總結(jié),其中SpringBoot使用的2.4.5版本,本文通過(guò)業(yè)務(wù)流程圖實(shí)例代碼相結(jié)合給大家介紹的非常詳細(xì),需要的朋友參考下吧2021-06-06

