#前言:這個是大二做的課設(還是學生管理系統…),理論上雖然是4個人一組一起做的,但是,注意這個“但是”,還是我一個人承擔了所有…代碼和文檔基本都是我一個人寫的,當初直接肝得吐血,這也是為啥後面的Web 版部分功能沒有完成的原因。
專案分成一個JavaSwing寫的GUI桌面應用程式和一個半成品的網路應用,下圖是專案的整體功能結構展示
JavaSwing這裡使用的是MyBatis Spring 的框架組合,後面發現使用Spring 框架在Swing 開發的程式上好像是個錯誤。
另外,JavaSwing 版裡面可能還有一些邏輯上的未知 bug。
1、登入模組
#2、系統設定模組
3、學生管理模組
學生添加
#學生列表
4、班級管理模組
班級新增
班級管理
##5、成績管理成績統計 6、網頁版點擊後可以跳到瀏覽器的
http://localhost:8080 網址
##啟動專案的話就執行view 套件裡面的LoginFrm
#遇到的問題
Swing 是Java 的一個進行GUI 開發的包,在課設中我使用Spring 對容器進行管理,但是在使用Spring 註解進行容器依賴注入的時候出現了一個問題,依賴注入為null,報錯如下:
Exception in thread “AWT-EventQueue-0” java.lang.NullPointerExceptionat com.view.LoginFrm.loginAct(LoginFrm.java:187)
# at com.view.LoginFrm$2.actionPerformed(LoginFrm.java:96)
在百度找了許久沒找到問題所在,排除了Spring 設定檔寫錯、或者是沒加@Service 註解等問題之後,我找到了網路上的解釋,如下:
在多執行緒時使用@Autowired 總是取得不到bean。
原因是:new thread 不在Spring 容器中,也就無法獲得Spring 中的bean 物件
JavaSwing 不是線程安全的,專案中一些地方是多線程運行的,許多UI 線程在裡面並發運行,所以在這些線程裡面使用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 的依賴沒啥區別,使用了Spring 反而更麻煩了一些
Mybatis使用HashMap作為結果集出現的問題
在編寫查找指定簽到方法的時候,我使用了List
@Results({
@Result(property = "key",column = "attendance_num",jdbcType = JdbcType.INTEGER),
@Result(property = "value",column = " attendance_date",jdbcType = JdbcType.VARCHAR)})
但是它顯示格式轉換錯誤,於是我在控制台輸出了一下查詢結果,發現結果是這樣的
[{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屬性值對應的是實體類別的屬性,但是HashMap裡面的key和vlaue並不能算屬性(是我想錯了),所以此時Mybatis就會自己設定一個屬性名,於是就變成了上面的結果。別問為啥不用xml檔案的形式,當時時間不太夠,就直接貪方便用註解了
#解決方法:
#將上面的結果值重新處理一下,再賦給HashMap
刪除帶外鍵關聯的資料時出現的問題
專案中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`)); pernotone exception SQLe. row: a foreign key constraint fails (`ttms`.`s_attendance`, CONSTRAINT `student_attendance_foreign` FOREIGN KEY (`student_id`) REFERENCES `s_student` (`id`))
##錯誤錯誤訊息,問題出在Dao層,一條刪除語句出現問題了,分析了一下原因,發現是設定了外鍵關聯,這導致我們無法刪除該條資料。
解決方法:
在刪除資料前先設定外鍵無效,如下:
set foreign_key_checks = 0;
#然後此時可以執行刪除語句了
刪除完之後再設定外鍵有效,如下:
##這樣就完美地刪除了這條記錄了。 JavaWebJavaWeb 這裡使用的是 SpringBoot Spring Data JPA 的框架組合,頁面是 Thymeleaf 進行資料展示的,頁面上有一個統計頁面使用了 ECharts 進行資料視覺化。 前面說到 Web 是一個半成品,它已經實現了的功能主要有登入、登出登入、、修改密碼、學生管理、班級管理、成績管理的成績統計這幾個功能模組。另外,它用的資料庫和 JavaSwing 版用的都是同一個,所以它們之前的資料其實是互通的。 總結:儘管頁面醜了點,但是它可以作為一個模板繼續開發下去。 功能展示1、登入介面 2、學生管理學生清單 #學生加入 3、班級管理班級清單 班級加上 4、成績統計 ##使用說明專案結構圖:set foreign_key_checks = 1;
#啟動的話直接進入DemoApplication 類別裡面右鍵啟動就可以了。
遇到的問題
###使用JPA更新資料庫時遇到的問題######使用Spring Data JPA 做Web 端的持久化層的內容時,遇到了一個錯誤,如下:#########Executing an update/delete query#########在百度查找一番之後,發現是JPA 如果執行update 或delete 等操作時,要在Dao 或Service層加上@Transactiona l註解,代表這是一個事務層級的操作,這相當於JPA 的一個使用規範吧,因為JPA 要求,’沒有事務支持,不能執行更新和刪除操作。 ###以上是分析Java實現的學生管理系統案例。的詳細內容。更多資訊請關注PHP中文網其他相關文章!