Java實現(xiàn)學(xué)生管理系統(tǒng)詳解
學(xué)生管理系統(tǒng)(Java版)
前言:這個是大二做的課設(shè)(還是學(xué)生管理系統(tǒng)…),理論上雖然是4個人一組一起做的,但是,注意這個“但是”,還是我一個人承擔了所有…代碼和文檔基本都是我一個人寫的,當初直接肝得吐血,這也是為啥后面的 Web 版部分功能沒有完成的原因。
項目介紹
項目分為一個JavaSwing寫的GUI桌面應(yīng)用和一個半成品的Web應(yīng)用,下圖是項目的整體功能結(jié)構(gòu)展示
JavaSwing
JavaSwing這里使用的是 MyBatis + Spring 的框架組合,后面發(fā)現(xiàn)使用 Spring 框架在 Swing 開發(fā)的程序上好像是一個錯誤。
另外,JavaSwing 版里面可能還有一些邏輯上的未知 bug。
功能展示(部分)
1、登錄模塊
2、系統(tǒng)設(shè)置模塊
3、學(xué)生管理模塊
學(xué)生添加
學(xué)生列表
4、班級管理模塊
班級添加
班級管理
5、成績管理
成績統(tǒng)計
6、網(wǎng)頁版
點擊后可以跳轉(zhuǎn)到瀏覽器的 http://localhost:8080 網(wǎng)址
使用說明
使用 IDEA 打開項目,項目的結(jié)構(gòu)如下圖:
啟動項目的話就運行 view 包里面的 LoginFrm
遇到的問題
使用Spring進行依賴注入遇到的問題
Swing 是 Java 的一個進行 GUI 開發(fā)的包,在課設(shè)中我使用 Spring 對容器進行管理,但是在使用 Spring 注解進行容器依賴注入的時候出現(xiàn)了一個問題,依賴注入為 null,報錯如下:
Exception in thread “AWT-EventQueue-0” java.lang.NullPointerException
at com.view.LoginFrm.loginAct(LoginFrm.java:187)
at com.view.LoginFrm$2.actionPerformed(LoginFrm.java:96)
在百度找了許久沒找到問題所在,排除了 Spring 配置文件寫錯、或者是沒加 @Service 注解等問題之后,我找到了網(wǎng)上的一個解釋,如下:
在多線程時使用 @Autowired 總是獲取不到 bean。
原因是:new thread 不在 Spring 容器中,也就無法獲得 Spring 中的 bean 對象
JavaSwing 不是線程安全的,項目中一些地方是多線程運行的,許多 UI 線程在里面并發(fā)運行,所以在這些線程里面使用 Spring 注入失敗,因為它們不是 Spring 管理的線程
而Spring在多線程的情況下是不允許使用注解注入依賴的,所以我們只能手動get到我們想要的bean對象,代碼如下:
private final ApplicationContext context = new ClassPathXmlApplicationContext("spring.xml"); private final AdminService adminService = (AdminServiceImpl)context.getBean("AdminServiceImpl");
其實還可以通過配置線程池的方法管理,但是 Swing 我又不太熟,不知道它運行時有哪幾個線程。
這個問題是我當初沒想到的,如果我知道的話就不會用 Spring 在Swing 上面了…因為自己每個 view 層的類上都要手動獲取依賴,比其實跟自己使用一個單例模式獲取 MyBatis 的依賴沒啥區(qū)別,使用了 Spring 反而更麻煩了一些
Mybatis使用HashMap作為結(jié)果集出現(xiàn)的問題
在編寫查找指定簽到方法的時候,我使用了List<HashMap<String,String>>作為返回值,但是它卻顯示錯誤,第一次是顯示空指針錯誤,然后我配置了一下@Results結(jié)果集,如下:
@Results({ @Result(property = "key",column = "attendance_num",jdbcType = JdbcType.INTEGER), @Result(property = "value",column = "attendance_date",jdbcType = JdbcType.VARCHAR)})
但是它顯示格式轉(zhuǎn)換錯誤,于是我在控制臺輸出了一下查詢結(jié)果,發(fā)現(xiàn)結(jié)果是這樣的
[{value=2018-05-17, key=1},
{value=2018-04-17, key=1},
{value=2018-04-18, key=1},
{value=2018-04-19, key=3},
{value=2018-04-20, key=1},
{value=2018-04-21, key=1},
{value=2018-05-03, key=1}]
HashMap里面的值從JSON字符串的形式變成了xxx=xxx的形式,property屬性值對應(yīng)的是實體類的屬性,但是HashMap里面的key和vlaue并不能算屬性(是我想錯了),所以此時Mybatis就會自己設(shè)置一個屬性名,于是就變成了上面的結(jié)果。別問為啥不用xml文件的形式,當時時間不太夠,就直接貪方便用注解了
解決方法:
將上面的結(jié)果值重新處理一下,再賦給HashMap
刪除帶外鍵關(guān)聯(lián)的數(shù)據(jù)時出現(xiàn)的問題
項目中Service層報錯,如下:
Cannot delete or update a parent row: a foreign key constraint fails (`ttms`.`s_attendance`, CONSTRAINT `student_attendance_foreign` FOREIGN KEY (`student_id`) REFERENCES `s_student` (`id`)); nested exception is java.sql.SQLIntegrityConstraintViolationException: Cannot delete or update a parent row: a foreign key constraint fails (`ttms`.`s_attendance`, CONSTRAINT `student_attendance_foreign` FOREIGN KEY (`student_id`) REFERENCES `s_student` (`id`))
查看了一下錯誤信息,問題出在Dao層,一條刪除語句出現(xiàn)問題了,分析了一下原因,發(fā)現(xiàn)是設(shè)置了外鍵關(guān)聯(lián),這導(dǎo)致我們無法刪除該條數(shù)據(jù)。
解決方法:
在刪除數(shù)據(jù)前先設(shè)置外鍵無效,如下:
set foreign_key_checks = 0;
然后此時可以執(zhí)行刪除語句了
刪除完之后再設(shè)置外鍵有效,如下:
set foreign_key_checks = 1;
這樣就完美地刪除了這條記錄了。
JavaWeb
JavaWeb 這里使用的是 SpringBoot + Spring Data JPA 的框架組合,頁面是 Thymeleaf 進行數(shù)據(jù)展示的,頁面上有一個統(tǒng)計頁面使用了 ECharts 進行數(shù)據(jù)可視化。
前面說到 Web 是一個半成品,它已經(jīng)實現(xiàn)了的功能主要有登錄、退出登錄、、修改密碼、學(xué)生管理、班級管理、成績管理的成績統(tǒng)計這幾個功能模塊。另外,它用的數(shù)據(jù)庫和 JavaSwing 版用的是同一個,所以它們之前的數(shù)據(jù)其實是互通的。
總結(jié):盡管頁面丑了點,但是它可以作為一個模板繼續(xù)開發(fā)下去。
功能展示(部分)
1、登錄界面
2、學(xué)生管理
學(xué)生列表
學(xué)生添加
3、班級管理
班級列表
班級添加
4、成績統(tǒng)計
使用說明
項目結(jié)構(gòu)圖:
啟動的話直接進入 DemoApplication
類里面右鍵啟動就可以了。
遇到的問題
使用JPA更新數(shù)據(jù)庫時遇到的問題
使用 Spring Data JPA 做 Web 端的持久化層的內(nèi)容時,遇到了一個錯誤,如下:
Executing an update/delete query
在百度查找一番之后,發(fā)現(xiàn)是 JPA 如果執(zhí)行 update 或 delete 等操作時,要在 Dao 或者 Service 層加上 @Transactiona l注解,代表這是一個事務(wù)級別的操作,這相當于 JPA 的一個使用規(guī)范吧,因為 JPA 要求,'沒有事務(wù)支持,不能執(zhí)行更新和刪除操作'。
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
- Java+Mysql學(xué)生管理系統(tǒng)源碼
- java學(xué)生管理系統(tǒng)界面簡單實現(xiàn)(全)
- Java基于MySQL實現(xiàn)學(xué)生管理系統(tǒng)
- 簡單實現(xiàn)Java版學(xué)生管理系統(tǒng)
- Java實現(xiàn)學(xué)生管理系統(tǒng)
- java實現(xiàn)學(xué)生管理系統(tǒng)(面向?qū)ο?
- java設(shè)計簡單學(xué)生管理系統(tǒng)
- java實現(xiàn)簡單學(xué)生管理系統(tǒng)項目
- java基于jdbc實現(xiàn)簡單學(xué)生管理系統(tǒng)
- springboot實現(xiàn)學(xué)生管理系統(tǒng)
相關(guān)文章
spring framework體系結(jié)構(gòu)及模塊jar依賴關(guān)系詳解
在本篇文章里小編給大家整理的是關(guān)于spring framework體系結(jié)構(gòu)及模塊jar依賴關(guān)系,對此有興趣的朋友們可以學(xué)習(xí)下。2019-09-09Java中的有限狀態(tài)機(設(shè)計模式——狀態(tài)模式)
這篇文章主要介紹了Java中的有限狀態(tài)機(設(shè)計模式——狀態(tài)模式),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-08-08Spring Boot Event Bus用法小結(jié)
Spring Boot Event Bus是Spring框架中事件驅(qū)動編程的一部分,本文主要介紹了Spring Boot Event Bus用法小結(jié),感興趣的可以了解一下2023-09-09Spring MVC數(shù)據(jù)綁定概述及原理詳解
這篇文章主要介紹了Spring MVC數(shù)據(jù)綁定概述及原理詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-06-06