<form id="3hdj5"></form>

<form id="3hdj5"></form>

        <noframes id="3hdj5"><form id="3hdj5"><nobr id="3hdj5"></nobr></form>

          <form id="3hdj5"></form>

          <noframes id="3hdj5">

          學生管理系統(Java版)

          35 篇文章 0 訂閱
          33 篇文章 0 訂閱

          學生管理系統(Java版)

          前言:這個是大二做的課設(還是學生管理系統…),理論上雖然是4個人一組一起做的,但是,注意這個“但是”,還是我一個人承擔了所有…代碼和文檔基本都是我一個人寫的,當初直接肝得吐血,這也是為啥后面的 Web 版部分功能沒有完成的原因。

          項目介紹

          項目分為一個JavaSwing寫的GUI桌面應用和一個半成品的Web應用,下圖是項目的整體功能結構展示

          請添加圖片描述

          JavaSwing

          JavaSwing這里使用的是 MyBatis + Spring 的框架組合,后面發現使用 Spring 框架在 Swing 開發的程序上好像是一個錯誤。
          另外,JavaSwing 版里面可能還有一些邏輯上的未知 bug。

          功能展示(部分)

          1、登錄模塊

          在這里插入圖片描述

          2、系統設置模塊
          在這里插入圖片描述
          3、學生管理模塊

          學生添加
          在這里插入圖片描述

          學生列表
          在這里插入圖片描述

          4、班級管理模塊

          班級添加
          在這里插入圖片描述

          班級管理
          在這里插入圖片描述

          5、成績管理

          成績統計
          在這里插入圖片描述

          6、網頁版
          點擊后可以跳轉到瀏覽器的 http://localhost:8080 網址
          在這里插入圖片描述

          使用說明

          使用 IDEA 打開項目,項目的結構如下圖:
          在這里插入圖片描述

          啟動項目的話就運行 view 包里面的 LoginFrm
          在這里插入圖片描述

          遇到的問題

          使用Spring進行依賴注入遇到的問題

          Swing 是 Java 的一個進行 GUI 開發的包,在課設中我使用 Spring 對容器進行管理,但是在使用 Spring 注解進行容器依賴注入的時候出現了一個問題,依賴注入為 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 注解等問題之后,我找到了網上的一個解釋,如下:
          在多線程時使用 @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<HashMap<String,String>>作為返回值,但是它卻顯示錯誤,第一次是顯示空指針錯誤,然后我配置了一下@Results結果集,如下:

          @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`)); 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層,一條刪除語句出現問題了,分析了一下原因,發現是設置了外鍵關聯,這導致我們無法刪除該條數據。

          解決方法:
          在刪除數據前先設置外鍵無效,如下:

          set foreign_key_checks = 0;
          

          然后此時可以執行刪除語句了
          刪除完之后再設置外鍵有效,如下:

          set foreign_key_checks = 1;
          

          這樣就完美地刪除了這條記錄了。

          JavaWeb

          JavaWeb 這里使用的是 SpringBoot + Spring Data JPA 的框架組合,頁面是 Thymeleaf 進行數據展示的,頁面上有一個統計頁面使用了 ECharts 進行數據可視化。
          前面說到 Web 是一個半成品,它已經實現了的功能主要有登錄、退出登錄、、修改密碼、學生管理、班級管理、成績管理的成績統計這幾個功能模塊。另外,它用的數據庫和 JavaSwing 版用的是同一個,所以它們之前的數據其實是互通的。
          總結:盡管頁面丑了點,但是它可以作為一個模板繼續開發下去。

          功能展示(部分)

          1、登錄界面

          在這里插入圖片描述

          2、學生管理

          學生列表
          在這里插入圖片描述
          學生添加
          在這里插入圖片描述

          3、班級管理

          班級列表
          在這里插入圖片描述

          班級添加
          在這里插入圖片描述

          4、成績統計
          在這里插入圖片描述

          在這里插入圖片描述

          在這里插入圖片描述

          使用說明

          項目結構圖:
          在這里插入圖片描述

          啟動的話直接進入 DemoApplication 類里面右鍵啟動就可以了。

          遇到的問題

          使用JPA更新數據庫時遇到的問題

          使用 Spring Data JPA 做 Web 端的持久化層的內容時,遇到了一個錯誤,如下:

          Executing an update/delete query
          

          在百度查找一番之后,發現是 JPA 如果執行 update 或 delete 等操作時,要在 Dao 或者 Service 層加上 @Transactiona l注解,代表這是一個事務級別的操作,這相當于 JPA 的一個使用規范吧,因為 JPA 要求,’沒有事務支持,不能執行更新和刪除操作’。

          最后

          項目地址如下:
          Github 地址:https://github.com/guanchanglong/StudentManagementSystem-Java
          麻煩各位可否在看代碼的時候順手給一顆星 ^ _ ^,舉手之勞感激不盡。

          PS:也可以到我的個人博客查看更多內容
          個人博客地址:小關同學的博客

          “相關推薦”對你有幫助么?

          • 非常沒幫助
          • 沒幫助
          • 一般
          • 有幫助
          • 非常有幫助
          提交
          ??2022 CSDN 皮膚主題:深藍海洋 設計師:CSDN官方博客 返回首頁

          打賞作者

          m0_60721514

          你的鼓勵將是我創作的最大動力

          ¥2 ¥4 ¥6 ¥10 ¥20
          輸入1-500的整數
          余額支付 (余額:-- )
          掃碼支付
          掃碼支付:¥2
          獲取中
          掃碼支付

          您的余額不足,請更換掃碼支付或充值

          打賞作者

          實付
          使用余額支付
          點擊重新獲取
          掃碼支付
          錢包余額 0

          抵扣說明:

          1.余額是錢包充值的虛擬貨幣,按照1:1的比例進行支付金額的抵扣。
          2.余額無法直接購買下載,可以購買VIP、C幣套餐、付費專欄及課程。

          余額充值
          狠狠激情五月丁香免费视频