小型工資管理軟件_java+oracle_軟件綜合課程設(shè)計_第1頁
已閱讀1頁,還剩29頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論