這篇文章將為大家詳細(xì)講解有關(guān)使用JDBC怎么實現(xiàn)一個學(xué)生管理系統(tǒng),文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供伍家崗網(wǎng)站建設(shè)、伍家崗做網(wǎng)站、伍家崗網(wǎng)站設(shè)計、伍家崗網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、伍家崗企業(yè)網(wǎng)站模板建站服務(wù),十載伍家崗做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。
1、學(xué)生類
package manage;
import java.util.Date;
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
*/
//數(shù)據(jù)庫的工具類
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;
/**
* 添加學(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è)置第一個參數(shù)
ps.setString(2, student.getSex()); //設(shè)置第二個參數(shù)
ps.setString(3, student.getName()); //設(shè)置第三個參數(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("請輸入學(xué)生年齡");
int age = scan.nextInt();
System.out.println("請輸入學(xué)生性別");
String sex = scan.next();
System.out.println("請輸入學(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è)置第一個參數(shù)
ps.setString(2, student.getSex()); //設(shè)置第二個參數(shù)
ps.setString(3, student.getName()); //設(shè)置第三個參數(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("請輸入學(xué)生id");
int id = scan.nextInt();
System.out.println("請輸入學(xué)生年齡");
int age = scan.nextInt();
System.out.println("請輸入學(xué)生性別");
String sex = scan.next();
System.out.println("請輸入學(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è)置第一個參數(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("請輸入學(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)行以下哪項操作");
System.out.println("1、添加學(xué)生 2、更新學(xué)生數(shù)據(jù) 3、學(xué)生信息查詢 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("沒有該操作選項,請重新來過!");
main(args);
break;
}
}
}
}關(guān)于使用JDBC怎么實現(xiàn)一個學(xué)生管理系統(tǒng)就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
當(dāng)前題目:使用JDBC怎么實現(xiàn)一個學(xué)生管理系統(tǒng)
鏈接地址:http://chinadenli.net/article46/ggjhhg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、品牌網(wǎng)站建設(shè)、品牌網(wǎng)站設(shè)計、自適應(yīng)網(wǎng)站、網(wǎng)站維護(hù)、靜態(tài)網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)