基于JDBC的Java控制臺應(yīng)用 - 學(xué)生信息管理系統(tǒng)

幫同學(xué)寫一個小程序, 通過JDBC連接MySQL數(shù)據(jù)庫, 來操作相關(guān)數(shù)據(jù)表, 并記錄和查詢信息, 沒有圖形界面, 是基于控制臺來操作的.


xx管理系統(tǒng).png

項目結(jié)構(gòu)圖:


項目結(jié)構(gòu)圖.png

其中
vo包里面的User類是一個JavaBean實(shí)體類
view包提供無限循環(huán)的顯示菜單
util工具包, 包括數(shù)據(jù)類型的轉(zhuǎn)換, 數(shù)據(jù)庫驅(qū)動的連接, 封裝好的鍵盤錄入操作
driver包: 包含main方法, 是程序的入口, 來啟動項目
dao(data access object)包: 定義操作數(shù)據(jù)庫數(shù)據(jù)的接口和它的實(shí)現(xiàn)類

相關(guān)代碼:
UserManager.java:

package driver;

import view.Menu;

public class UserManager {

    public static void main(String[] args) {
        new Menu();
    }

}

Menu.java:

package view;

import util.InputData;
import dao.IUserDAOImp;
import vo.User;

import java.util.List;

public class Menu {
    IUserDAOImp iu = new IUserDAOImp();
    InputData input = new InputData();

    public Menu() {
        while (true) {
            this.show();
        }
    }

    public void show() {
        System.out.println("--------人員信息管理系統(tǒng)-------");
        System.out.println("1.增加人員");
        System.out.println("2.按編號刪除人員");
        System.out.println("3.按編號修改人員信息");
        System.out.println("4.按編號查詢?nèi)藛T信息");
        System.out.println("5.按關(guān)鍵字查詢?nèi)藛T信息");
        System.out.println("0.退出");

        User user = null;
        int i = input.getInt("請選擇:", "請輸入正確的選項!");
        switch (i) {
            case 1:
                int id = input.getInt("請輸入人員編號:", "格式不對,請重新輸入!");
                String name = input.getString("請輸入人員姓名:");
                String sex = input.getString("請輸入性別:");
                java.util.Date birthday = input.getDate("請輸入出生日期:", "格式不對,請重新輸入!");
                user = new User(id, name, sex, birthday);
                if (iu.doInsert(user)) {
                    System.out.println("添加成功!");
                } else {
                    System.out.println("添加失??!");
                }
                break;
            case 2:
                int id2 = input.getInt("請輸入人員編號:", "格式不對,請重新輸入!");
                try {
                    if (iu.doDelete(id2)) {
                        System.out.println("刪除成功!");
                    } else {
                        System.out.println("刪除失敗!");
                    }
                } catch (Exception e1) {
                    e1.printStackTrace();
                }
                break;
            case 3:
                int id3 = input.getInt("請輸入人員編號:", "格式不對,請重新輸入!");
                String name3 = input.getString("請輸入人員姓名:");
                String sex3 = input.getString("請輸入性別:");
                java.util.Date birthday3 = input.getDate("請輸入出生日期:", "格式不對,請重新輸入!");
                user = new User(id3, name3, sex3, birthday3);
                try {
                    if (iu.doUpdate(id3, user)) {
                        System.out.println("修改成功!");
                    } else {
                        System.out.println("修改失??!");
                    }
                } catch (Exception e1) {
                    e1.printStackTrace();
                }
                break;
            case 4:
                int id4 = input.getInt("請輸入人員編號:", "格式不對,請重新輸入!");
                try {
                    user = iu.findById(id4);
                    System.out.println(user);
                } catch (Exception e1) {
                    e1.printStackTrace();
                }
                break;
            case 5:
                String keyword5 = input.getString("請輸入查詢關(guān)鍵字");
                try {
                    List<User> list = iu.findByKey(keyword5);
                    for (User u : list) {
                        System.out.println(u);
                    }
                } catch (Exception e) {
                    e.printStackTrace();
                }
                break;

            case 0:
                System.exit(1);
                break;
            default:
                System.out.println("請選擇正確的操作!");
        }
    }
}

數(shù)據(jù)庫操作:

數(shù)據(jù)庫操作png

SQL語句:

use `usermanage`;
create table `user`(
    id int primary key,
    name varchar(25),
    sex varchar(5),
    birthday date
);

演示結(jié)果:


演示.gif

最后注意:
該項目因?yàn)槟承┰? 是GBK編碼, 所以為了避免亂碼, 需要設(shè)置項目的編碼為GBK, Eclipse的設(shè)置同理. 同時, 里面包含.classpath和.project文件, 也可以直接通過Eclipse打開!


GBK.png

完整代碼:
https://github.com/menglanyingfei/Java/blob/master/CodeCollection/JavaSEProjects/JDBC/JDBC.zip

@Author menglanyingfei
@Created on 2017.11.30

博客地址

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,109評論 25 709
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法,繼承相關(guān)的語法,異常的語法,線程的語...
    子非魚_t_閱讀 34,734評論 18 399
  • 每次想寫點(diǎn)什么都不盡我意,可能是因?yàn)闆]有大綱,沒有主線,寫著寫著就跑偏了。(大笑:哈哈哈哈哈) 這次就先寫最近的我...
    免辣閱讀 569評論 0 0
  • 時間在那里, 你也在那里。 時間從這里過去, 你也從這里過去。 時間在奔跑, 你也在奔跑。 時間午休一會兒, 你也...
    小劇在成長閱讀 375評論 4 12
  • 收到微信消息的時候,蘇旖旎正在加班,她沒回復(fù)只是隨手把會議資料準(zhǔn)備好,號召著辦公室里的同事開緊急會議。會一開便到了...
    谷谷閱讀 2,562評論 4 12

友情鏈接更多精彩內(nèi)容