版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p> 課 程 設(shè) 計 報 告</p><p> 課程設(shè)計名稱:軟件綜合課程設(shè)計</p><p> 課程設(shè)計題目:工資管理軟件</p><p> 院(系):計算機學(xué)院</p><p> 專 業(yè):計算機科學(xué)與技術(shù)</p><p><b> 班 級: </b><
2、;/p><p><b> 學(xué) 號: </b></p><p><b> 目 錄</b></p><p> 第1章 概要設(shè)計1</p><p> 1.1 題目的內(nèi)容與要求1</p><p> 1.2 需求分析簡述1</p><p&g
3、t; 1.3 數(shù)據(jù)庫概念模型設(shè)計2</p><p> 1.3.1 E-R圖2</p><p> 1.3.2職工實體圖2</p><p> 1.3.3職工工資實體圖3</p><p> 1.4 總體方案設(shè)計3</p><p> 第2章 詳細(xì)設(shè)計4</p><p>
4、2.1數(shù)據(jù)庫邏輯模型設(shè)計4</p><p> 2.1.1 職工表(Emp)4</p><p> 2.1.2 職工工資表(Sal)4</p><p> 2.2系統(tǒng)功能詳細(xì)設(shè)計5</p><p> 2.2.1職工錄入流程5</p><p> 2.2.2查詢職工流程6</p><p&
5、gt; 2.2.3工資統(tǒng)計流程7</p><p> 2.2.4打印工資流程7</p><p> 2.2.5更新維護流程8</p><p> 第3章 調(diào)試分析9</p><p> 3.1 問題調(diào)試9</p><p> 3.2 結(jié)果分析9</p><p> 第4章
6、使用說明10</p><p> 4.1 主界面10</p><p> 4.2 錄入職工10</p><p> 4.3 查詢職工11</p><p> 4.4 工資統(tǒng)計12</p><p> 4.5 打印工資13</p><p> 4.6 更新維護14<
7、/p><p><b> 參考文獻(xiàn)16</b></p><p> 附 錄(部分程序清單)17</p><p><b> 第1章 概要設(shè)計</b></p><p> 1.1 題目的內(nèi)容與要求</p><p> 為一般企業(yè)事業(yè)單位財務(wù)科開發(fā)一個簡單的工資管理軟件,使
8、財務(wù)工作人員能夠輕松管理工資臺賬業(yè)務(wù),實現(xiàn)其業(yè)務(wù)的計算機信息管理。</p><p> (1)職工基本信息的錄入:包括職工號、職工姓名、參加工作時間、職稱、職務(wù)、工資級別、基本工資、職務(wù)工資、崗位津貼等;</p><p> (2)信息查詢:按職工姓名、職工號、職務(wù)等進(jìn)行靈活多樣的查詢;</p><p> (3)信息更新維護:單個更新、批量修改、刪除、增加新記錄等
9、;</p><p> (4)統(tǒng)計報表:生成工資條,年月工資按單位統(tǒng)計,生成報表并打??;</p><p> (5)工資信息條包括:參加工作時間、職工號、職工姓名、基本工資、崗位津貼、獎金、補貼、扣病事假、扣稅金、實發(fā)工資等;</p><p> (6)如果沒有打印機,則以屏幕輸出代替打印功能;</p><p> (7)人機交互界面采用可視
10、化界面;</p><p> (8)按要求寫出課程設(shè)計報告。</p><p> 1.2 需求分析簡述</p><p> 根據(jù)本次課程設(shè)計任務(wù)書的要求,本次課設(shè)的主要任務(wù)是對數(shù)據(jù)庫中的表進(jìn)行增刪改查操作。</p><p> (1)由于是對公司職員的信息進(jìn)行操作,所以需要在數(shù)據(jù)庫中建立一個Emp表,用來存儲職工的各類信息,如職工號、姓名、工
11、作時間等。</p><p> (2)由于工資總類比較多,為了方便管理,在數(shù)據(jù)庫中建立Sal表,用來存儲員工的工資,如基本工資、職務(wù)工資和崗位津貼等。</p><p> (3)由于需要用高級語言對數(shù)據(jù)庫進(jìn)行操作,所以需要將Java和Oracle連接在一起,連接后用Java中對數(shù)據(jù)庫操作的語句對數(shù)據(jù)進(jìn)行相應(yīng)的操作。</p><p> 1.3 數(shù)據(jù)庫概念模型設(shè)計&
12、lt;/p><p> 1.3.1 E-R圖</p><p> 工資管理軟件共有兩個實體,分別是職工實體和職工工資實體,他們之間的關(guān)系是管理。E-R圖如圖1.1所示。</p><p><b> 圖1.1 E-R圖</b></p><p> 1.3.2職工實體圖</p><p> 工資管理軟件在
13、數(shù)據(jù)庫中有一個表Emp,所對應(yīng)的是職工實體,職工的屬性有職工編號、職工姓名、職工的入職日期、職工職務(wù)和職工職位,職工實體圖如圖1.2所示。</p><p><b> 圖1.2職工實體圖</b></p><p> 1.3.3職工工資實體圖</p><p> 在數(shù)據(jù)庫中創(chuàng)建表Sal,所對應(yīng)的是職工工資實體,職工工資的屬性有工資級別、基本工資、
14、職務(wù)工資、崗位津貼、獎金、補貼、扣病事假和職工編號,職工工資實體圖如圖1.3所示。</p><p> 圖1.3職工工資實體圖</p><p> 1.4 總體方案設(shè)計</p><p> 本次課設(shè)要實現(xiàn)的功能是對職工工資的各種操作,共有五大模塊分別是職工信息的錄入、職工信息的查詢、職工工資的統(tǒng)計、打印工資和職工信息的更新維護。系統(tǒng)總體模塊圖如圖1.4所示。<
15、;/p><p> 圖1.4 系統(tǒng)總體模塊圖</p><p><b> 第2章 詳細(xì)設(shè)計</b></p><p> 2.1數(shù)據(jù)庫邏輯模型設(shè)計</p><p> 2.1.1 職工表(Emp) </p><p> 職工表用來存放職工的基本信息,其中包括職工編號、職工姓名、職工入職日期、職工職務(wù)、
16、職工職位。職工表如表2.1所示。</p><p><b> 表2.1 職工表</b></p><p> 2.1.2 職工工資表(Sal) </p><p> 職工工資表用來存放職工的工資信息,包括職工級別、基本工資、職務(wù)工資、崗位津貼、獎金、補貼、扣病事假和職工編號。職工工資表如表2.2所示。</p><p>
17、表2.2 職工工資表</p><p> 2.2系統(tǒng)功能詳細(xì)設(shè)計</p><p> 本工資管理軟件共分為五大模塊,分別是職工信息的錄入,職工信息的查詢,職工工資的統(tǒng)計,打印工資和職工信息的更新維護。</p><p> 2.2.1職工錄入流程 </p><p> 職工錄入時,首先需要輸入職工的信息,輸入完成后,點擊確定,職工信息錄入完成,
18、職工錄入流程圖如圖2.1所示。</p><p> 圖2.1職工錄入流程圖</p><p> 2.2.2查詢職工流程 </p><p> 查詢職工時,首先需要選擇查詢方式,查詢方式共有三種:按姓名查詢、按職工編號查詢和按職務(wù)查詢,如選擇的是按工號查詢,則需要輸入職工號,如果數(shù)據(jù)庫中存在該職工的信息,會將信息輸出,如果不存在,輸出錯誤信息。查詢職工流程圖如圖2.2
19、所示。</p><p> 圖2.2查詢職工流程圖</p><p> 2.2.3工資統(tǒng)計流程 </p><p> 工資統(tǒng)計時,首先需要輸入職工號,如果數(shù)據(jù)庫中存在該職工信息,會統(tǒng)計出該職工的基本信息以及應(yīng)發(fā)工資。如果不存在,輸出錯誤信息。工資統(tǒng)計流程圖如圖2.3所示。</p><p> 圖2.3工資統(tǒng)計流程圖</p>&l
20、t;p> 2.2.4打印工資流程 </p><p> 如果選擇了打印工資,會彈出窗口顯示所有員工的信息,以及扣除的稅金和實發(fā)的工資。打印工資流程圖如圖2.4所示。</p><p> 圖2.4打印工資流程圖</p><p> 2.2.5更新維護流程 </p><p> 更新維護時,首先需要選擇操作方式,刪除員工或單個更新或批量更
21、新。如果選擇刪除員工,需要輸入職工號,如果數(shù)據(jù)庫中存在該職工,則將該職工刪除,否則輸出錯誤信息。如果選擇的是單個更新,在輸入職工號后輸入新的數(shù)據(jù),并點擊確定,如果更新失敗,彈出錯誤信息。如果選擇的是批量更新,輸入新數(shù)據(jù)后點擊確定,如果更新失敗,彈出錯誤信息。更新維護流程圖如圖2.5所示。</p><p> 圖2.5更新維護流程圖</p><p><b> 第3章 調(diào)試分析&
22、lt;/b></p><p><b> 3.1 問題調(diào)試</b></p><p> ?。?)在執(zhí)行過程中,首次執(zhí)行會出現(xiàn)正確的結(jié)果,但是如果想要繼續(xù)執(zhí)行,就會出現(xiàn)異常,解決方法是每次在進(jìn)行操作后,都重新連接數(shù)據(jù)庫,否則數(shù)據(jù)庫與程序之間的連接會自動停止,無法正確運行。</p><p> (2)在查詢職工時,如果輸入的職工在數(shù)據(jù)庫中存在
23、,那么會正常的運行,但是如果輸入的職工在數(shù)據(jù)庫中并不存在,就會出現(xiàn)異常,解決方法是將查詢結(jié)果進(jìn)行判斷,如果存在則輸出,否則輸出錯誤信息。</p><p> ?。?)在建立職工工資表時,創(chuàng)建了稅金屬性和總工資屬性,但是由于職工的工資會進(jìn)行變化,從而導(dǎo)致稅金和總工資也會跟著變化,不能正確運行,解決方法是刪除稅金和總工資屬性,將兩者作為變量,用查詢的結(jié)果計算出二者的值,將此問題解決。</p><p&
24、gt; ?。?)在連接數(shù)據(jù)庫時,忘記將classes12.jar導(dǎo)入jar包,無法連接數(shù)據(jù)庫,程序不能正常運行,解決方法是將classes12.jar導(dǎo)入,使程序正常運行。由于Oracle數(shù)據(jù)庫服務(wù)設(shè)置成了手動啟動,所以在執(zhí)行程序之前必須將數(shù)據(jù)庫服務(wù)啟動,來維持程序正常運行。</p><p><b> 3.2 結(jié)果分析</b></p><p> 本次課程設(shè)計實現(xiàn)
25、了任務(wù)書所要求的全部功能,人機交互采用了可視化界面,操作簡單。查詢方式設(shè)置了按姓名、職務(wù)和職工編號三種方式,靈活方便。在程序的測試階段,驗證了極端的數(shù)據(jù),程序都能給出相應(yīng)的處理,并且能顯示出理想的結(jié)果,彈出相應(yīng)的對話框,提醒用戶應(yīng)該如何進(jìn)行下一步操作。</p><p><b> 第4章 使用說明</b></p><p><b> 4.1 主界面<
26、;/b></p><p> 程序運行后會彈出主界面,主界面如圖4.1所示。</p><p><b> 圖4.1主界面</b></p><p><b> 4.2 錄入職工</b></p><p> 點擊了職工錄入按鈕,會彈出如圖4.2所示的錄入職工界面。</p><
27、p> 圖4.2職工錄入界面</p><p> 在相應(yīng)的對話框中輸入職工的信息,并點擊確定,如果輸入的信息正確,就會提示職工錄入成功,否則提示職工錄入失敗,職工錄入正確的提示信息如圖4.3所示。</p><p> 圖4.3職工錄入成功界面</p><p><b> 4.3 查詢職工</b></p><p>
28、 點擊了職工查詢按鈕,會彈出如圖4.4所示的職工查詢界面。</p><p> 圖4.4職工查詢界面</p><p> 如果選擇了按職工號查詢,會彈出如圖4.5所示的界面。</p><p> 圖4.5按工號查詢界面</p><p> 輸入職工號后,如果數(shù)據(jù)庫中存在該職工的信息,就會彈出如圖4.6所示的職工信息界面。</p>
29、<p> 圖4.6查詢結(jié)果界面</p><p><b> 4.4 工資統(tǒng)計</b></p><p> 點擊了打印工資按鈕后,會彈出等待輸入職工編號的界面,如果輸入的職工在數(shù)據(jù)庫中不存在,會彈出統(tǒng)工資統(tǒng)計失敗的界面,如圖4.7所示。</p><p> 圖4.7工資統(tǒng)計失敗界面</p><p> 統(tǒng)
30、計報表界面如圖4.8所示。</p><p> 圖4.8統(tǒng)計報表界面</p><p><b> 4.5 打印工資</b></p><p> 點擊了打印工資按鈕后,會顯示如圖4.9所示的打印工資界面。</p><p> 圖4.9打印工資界面</p><p><b> 4.6 更
31、新維護</b></p><p> 在點擊了更新維護按鈕后,會顯示如圖4.10所示的界面。</p><p> 圖4.10更新維護界面</p><p> 如果選擇職工刪除,需要輸入職工號,如果輸入了正確的職工號,點擊確定后,會顯示職工刪除成功的信息。如圖4.11所示。</p><p> 圖4.11刪除成功界面</p>
32、;<p> 如果選擇了單個更新,首先要輸入職工編號,如圖4.12所示。</p><p> 圖4.12單個更新界面</p><p> 點擊確定后會顯示如圖4. 13的界面。</p><p> 圖4.13單個更新界面</p><p> 如果選擇了批量更新會顯示如圖4. 14所示的界面。</p><p&g
33、t; 圖4.14批量更新界面</p><p> 輸入了新數(shù)據(jù)后,點擊補貼,會顯示補貼更新成功的界面。如圖4.15所示。</p><p> 圖4.15補貼更新成功界面</p><p><b> 參考文獻(xiàn)</b></p><p> [1] 王珊,薩師煊. 數(shù)據(jù)庫系統(tǒng)概論[M].北京:北京高等教育出版社,2005&l
34、t;/p><p> [2](美)克羅恩科. 數(shù)據(jù)庫原理(第三版)[M].北京:清華大學(xué)出版社,2003</p><p> [3](美)John Lewis WillIam Lofttus .Java 程序設(shè)計基礎(chǔ)[M].北京:清華大學(xué)出版社,2004</p><p> [4]耿祥義. Java 面向?qū)ο蟪绦蛟O(shè)計[M].北京:清華大學(xué)出版社,2010</p&g
35、t;<p> [5]王鵬.Java Swing 圖形界面開發(fā)與案例詳解[M] .北京:清華大學(xué)出版社,2006</p><p> 附 錄(部分程序清單)</p><p> package DAO;</p><p> import Java.sql.Array;</p><p> import Java.sql.Co
36、nnection;</p><p> import Java.sql.DriverManager;</p><p> import Java.sql.PreparedStatement;</p><p> import Java.sql.ResultSet;</p><p> import Java.sql.SQLException;
37、</p><p> import Java.sql.Statement;</p><p> import GUI.SearchByNoGui;</p><p> import GUI.InMessageDialog;</p><p> import VO.Sall;</p><p> import VO.Us
38、erVo;</p><p> public class FunctionDao extends BaseDAO {</p><p><b> // 插入模塊</b></p><p> public int insert(Sall sal) {</p><p> int rows = 0;</p>&
39、lt;p><b> try {</b></p><p> connection.setAutoCommit(false);</p><p> String sql = "insert into sall values(?,?,?,?,?,?,?,?,?,?,?,?)";</p><p> ps = connec
40、tion.prepareStatement(sql);</p><p> ps.setString(1, sal.getNo());</p><p> ps.setString(2, sal.getName());</p><p> ps.setDate(3, sal.getdate());</p><p> ps.setString
41、(4, sal.getTitle());</p><p> ps.setString(5, sal.getPost());</p><p> ps.setInt(6, sal.getGrade());</p><p> ps.setFloat(7, sal.getSal());</p><p> ps.setFloat(8, sal.
42、getPostsal());</p><p> ps.setFloat(9, sal.getAllowance());</p><p> ps.setFloat(10, sal.getAward());</p><p> ps.setFloat(11, sal.getSubsidy());</p><p> ps.setFloat(1
43、2, sal.getThing());</p><p> rows = ps.executeUpdate();</p><p> if (rows > 0) {</p><p> connection.commit();</p><p><b> }</b></p><p> }
44、catch (SQLException e) {</p><p> e.printStackTrace();</p><p><b> try {</b></p><p> connection.rollback();</p><p> } catch (SQLException e1) {</p>
45、<p> e1.printStackTrace();</p><p><b> }</b></p><p> } finally {</p><p> this.closeAll();</p><p><b> }</b></p><p> retur
46、n rows;</p><p><b> }</b></p><p><b> // 按姓名查詢</b></p><p> public Sall searchByName(String s) {</p><p> Sall sal = null;</p><p>&
47、lt;b> try {</b></p><p> connection.setAutoCommit(false);</p><p> String sql = "select * from sall where sname = ?";</p><p> ps = connection.prepareStatement(s
48、ql);</p><p> ps.setString(1, s);</p><p> ResultSet rs = ps.executeQuery();</p><p> if (rs.next()) {</p><p> sal = new Sall(rs.getString(1), rs.getString(2), rs.getD
49、ate(3),</p><p> rs.getString(4), rs.getString(5), rs.getInt(6), rs</p><p> .getFloat(7), rs.getFloat(8), rs.getFloat(9));</p><p><b> }</b></p><p> } cat
50、ch (SQLException e) {</p><p> e.printStackTrace();</p><p><b> try {</b></p><p> connection.rollback();</p><p> } catch (SQLException e1) {</p>&l
51、t;p> e1.printStackTrace();</p><p><b> }</b></p><p> } finally {</p><p> this.closeAll();</p><p><b> }</b></p><p> return s
52、al;</p><p><b> }</b></p><p><b> // 按職工號查詢</b></p><p> public Sall searchByNo(String number) {</p><p> Sall sal = null;</p><p>&
53、lt;b> try {</b></p><p> connection.setAutoCommit(false);</p><p> String sql = "select * from sall where sno = ?";</p><p> ps = connection.prepareStatement(sql
54、);</p><p> ps.setString(1, number);</p><p> ResultSet rs = ps.executeQuery();</p><p> if (rs.next()) {</p><p> sal = new Sall(rs.getString(1), rs.getString(2), rs.g
55、etDate(3),</p><p> rs.getString(4), rs.getString(5), rs.getInt(6), rs</p><p> .getFloat(7), rs.getFloat(8), rs.getFloat(9));</p><p><b> }</b></p><p> }
56、catch (SQLException e) {</p><p> e.printStackTrace();</p><p><b> try {</b></p><p> connection.rollback();</p><p> } catch (SQLException e1) {</p>
57、<p> e1.printStackTrace();</p><p><b> }</b></p><p> } finally {</p><p> this.closeAll();</p><p><b> }</b></p><p> retur
58、n sal;</p><p><b> }</b></p><p><b> //刪除職工</b></p><p> public int delete(String no) {</p><p> int rows = 0;</p><p><b> tr
59、y {</b></p><p> connection.setAutoCommit(false);</p><p> String sql = "delete from sall where sno=?";</p><p> ps = connection.prepareStatement(sql);</p>&l
60、t;p> ps.setString(1, no);</p><p> rows = ps.executeUpdate();</p><p> if (rows > 0) {</p><p> connection.commit();</p><p><b> }</b></p><
61、;p> } catch (SQLException e) {</p><p> e.printStackTrace();</p><p><b> try {</b></p><p> connection.rollback();</p><p> } catch (SQLException e1) {&
62、lt;/p><p> e1.printStackTrace();</p><p><b> }</b></p><p> } finally {</p><p> this.closeAll();</p><p><b> }</b></p><p&
63、gt; return rows;</p><p><b> }</b></p><p><b> // 打印工資</b></p><p> public String salPrint() {</p><p> String s = "";</p><
64、;p><b> try {</b></p><p> connection.setAutoCommit(false);</p><p> String sql = "select * from sall ";</p><p> ps = connection.prepareStatement(sql);<
65、/p><p> ResultSet rs = ps.executeQuery();</p><p> s += "工號 姓名 職工入職時間 職務(wù) 職位 級別 基本工資 職務(wù)工資 崗位津貼 獎金 補貼 扣病事假 扣稅金 實發(fā)工資 "</p><p><b> + "\n
66、";</b></p><p> while (rs.next()) {</p><p> float sal = rs.getFloat(7);</p><p> float postsal = rs.getFloat(8);</p><p> float allowance = rs.getFloat(9);&
67、lt;/p><p> float award = rs.getFloat(10);</p><p> float subsidy = rs.getFloat(11);</p><p> float thing = rs.getFloat(12);</p><p> float tax = (float) ((sal + postsal +
68、 allowance + award</p><p> + subsidy - thing) * 0.02);</p><p> float zong = (float) ((sal + postsal + allowance + award</p><p> + subsidy - thing) * 0.98);</p><p>
69、s += rs.getString(1) + "\t";</p><p> s += rs.getString(2) + "\t";</p><p> s += rs.getString(3) + "\t";</p><p> s += rs.getString(4) + "\t"
70、;</p><p> s += rs.getString(5) + "\t";</p><p> s += rs.getString(6) + "\t";</p><p> s += sal + "\t";</p><p> s += postsal + "\t&q
71、uot;;</p><p> s += allowance + "\t";</p><p> s += award + "\t";</p><p> s += subsidy + "\t";</p><p> s += thing + "\t";</
72、p><p> s += tax + "\t";</p><p> s += zong + "\t";</p><p> s += "\n";</p><p><b> }</b></p><p> } catch (SQLExcep
73、tion e) {</p><p> e.printStackTrace();</p><p><b> try {</b></p><p> connection.rollback();</p><p> } catch (SQLException e1) {</p><p> e1.
74、printStackTrace();</p><p><b> }</b></p><p> } finally {</p><p> this.closeAll();</p><p><b> }</b></p><p><b> return s;&l
75、t;/b></p><p><b> }</b></p><p><b> //查詢管理員</b></p><p> public UserVo searchUser(String id) {</p><p> UserVo uv = null;</p><p>
76、;<b> try {</b></p><p> String sql = " select * from users where userid = ? ";</p><p> ps = connection.prepareStatement(sql);</p><p> ps.setString(1, id);&l
77、t;/p><p> ResultSet rs = ps.executeQuery();</p><p> if (rs.next())</p><p> uv = new UserVo(rs.getString(1), rs.getString(2));</p><p> } catch (SQLException e) {</p&
78、gt;<p> e.printStackTrace();</p><p><b> try {</b></p><p> connection.rollback();</p><p> } catch (SQLException e1) {</p><p> e1.printStackTrace(
79、);</p><p><b> }</b></p><p> } finally {</p><p> this.closeAll();</p><p><b> }</b></p><p> return uv;</p><p><b
80、> }</b></p><p><b> // 按職務(wù)查詢</b></p><p> public Sall searchByPost(String s) {</p><p> Sall sal = null;</p><p><b> try {</b></p&g
81、t;<p> connection.setAutoCommit(false);</p><p> String sql = "select * from sall where post = ?";</p><p> ps = connection.prepareStatement(sql);</p><p> ps.setS
82、tring(1, s);</p><p> ResultSet rs = ps.executeQuery();</p><p> if (rs.next()) {</p><p> sal = new Sall(rs.getString(1), rs.getString(2), rs.getDate(3),</p><p> rs.g
83、etString(4), rs.getString(5), rs.getInt(6), rs</p><p> .getFloat(7), rs.getFloat(8), rs.getFloat(9));</p><p><b> }</b></p><p> } catch (SQLException e) {</p>&
84、lt;p> e.printStackTrace();</p><p><b> try {</b></p><p> connection.rollback();</p><p> } catch (SQLException e1) {</p><p> e1.printStackTrace();<
85、/p><p><b> }</b></p><p> } finally {</p><p> this.closeAll();</p><p><b> }</b></p><p> return sal;</p><p><b>
86、 }</b></p><p><b> //單個更新</b></p><p> public int ReNewOnly(String a, String b, String c) {</p><p> int rows = 0;</p><p><b> try {</b>&l
87、t;/p><p> connection.setAutoCommit(false);</p><p> String sql = "update sall set "+a+" = ? where sno = ?"; </p><p> ps = connection.prepareStatement(sql);</p&
88、gt;<p> ps.setString(1, b);</p><p> ps.setString(2, c);</p><p> connection.commit();</p><p> rows = ps.executeUpdate();</p><p> if (rows > 0) {</p>
89、<p> connection.commit();</p><p><b> }</b></p><p> } catch (SQLException e) {</p><p> e.printStackTrace();</p><p><b> try {</b></
90、p><p> connection.rollback();</p><p> } catch (SQLException e1) {</p><p> e1.printStackTrace();</p><p><b> }</b></p><p> } finally {</p>
91、;<p> this.closeAll();</p><p><b> }</b></p><p> return rows;</p><p><b> }</b></p><p><b> //批量更新</b></p><p>
92、 public int ReNewAll(String a1, String a2) {</p><p> int rows = 0;</p><p><b> try {</b></p><p> connection.setAutoCommit(false);</p><p> String sql = &
93、quot;update sall set "+a1+" = ? "; </p><p> ps = connection.prepareStatement(sql);</p><p> ps.setString(1, a2);</p><p> connection.commit();</p><p>
94、rows = ps.executeUpdate();</p><p> if (rows > 0) {</p><p> connection.commit();</p><p><b> }</b></p><p> } catch (SQLException e) {</p><p&
95、gt; e.printStackTrace();</p><p><b> try {</b></p><p> connection.rollback();</p><p> } catch (SQLException e1) {</p><p> e1.printStackTrace();</p>
96、;<p><b> }</b></p><p> } finally {</p><p> this.closeAll();</p><p><b> }</b></p><p> return rows;</p><p><b> }&
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 工資管理系統(tǒng)--軟件工程課程設(shè)計
- 軟件工程課程設(shè)計----工資管理系統(tǒng)
- java工資管理系統(tǒng)課程設(shè)計
- 軟件工程課程設(shè)計--企業(yè)工資管理系統(tǒng)
- 軟件工程課程設(shè)計--員工工資管理系統(tǒng)
- 課程設(shè)計--小型公司工資管理系統(tǒng)的設(shè)計
- 學(xué)校內(nèi)部工資管理系統(tǒng)軟件工程課程設(shè)計
- c++課程設(shè)計--小型公司工資管理系統(tǒng)
- ”小型公司工資管理系統(tǒng)設(shè)計“c++課程設(shè)計
- 小型公司工資管理系統(tǒng)設(shè)計 c++課程設(shè)計
- 課程設(shè)計--超市庫存管理軟件設(shè)計
- 工資管理系統(tǒng)課程設(shè)計
- 工資管理系統(tǒng)課程設(shè)計
- 課程設(shè)計-工資管理系統(tǒng)
- D大學(xué)工資管理軟件項目的風(fēng)險管理研究.pdf
- 工資管理系統(tǒng)課程設(shè)計
- 工資管理系統(tǒng)課程設(shè)計
- 工資管理系統(tǒng)(課程設(shè)計)
- 軟件工程課程設(shè)計—— 大學(xué)工資管理系統(tǒng)的分析與設(shè)計
- 襄樊市勞動系統(tǒng)工資管理軟件的設(shè)計與實現(xiàn).pdf
評論
0/150
提交評論