2023年全國碩士研究生考試考研英語一試題真題(含答案詳解+作文范文)_第1頁
已閱讀1頁,還剩26頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、第11章 自定義員工請 假審批工作流,大連理工大學電子音像出版社 出版,第11章 自定義員工請假審批工作流,目的和要求:,掌握視圖的定義與使用掌握觸發(fā)器的定義與使用掌握 ADO.NET事務的定義與使用,重點和難點:,觸發(fā)器的定義與使用ADO.NET事務的定義與使用,模塊業(yè)務描述,第一級審批權限: 如果請假10天以上, 由員工提交請假申報,經教研室主任批準后,分別經系主任、副院長、院長逐級審批后,最后

2、由董事長批準終止流程。第二級審批權限:如果請假7-10天, 由員工提交請假申報,經教研室主任批準后,分別由系主任、副院長逐級審批, 最后由院長審批終止流程。第三級審批權限:如果請假3-7天, 由員工提交請假申報,經教研室主任批準后,再系主任審批,最后由副院長審批終止流程。第四級審批權限: 如果請假1-3天, 由員工提交請假申報,教研室主任批準,呈送經系主任審批終止流程。第五級審批權限: 如果請假1天,由員工提交請假申報,教研室主

3、任批準終止流程。,模塊 UML圖設計,,,模塊界面設計,基礎知識,視圖定義 視圖是一張?zhí)摂M表,它數據來源于基本表。優(yōu)點便于數據的操作,能將幾張表的中集中起來,可以簡化操作 示例一:CREATE VIEW view_name AS select_statement二例二:視圖示例一: CREATE VIEW SELECTEMPDEPASselect EmployeeID,EmployeeName,DepartmentNam

4、e from dbo.Employee E,dbo.Department D where D.DepID=E.DepartmentID,觸發(fā)器定義,觸發(fā)器是一種特殊的存儲過程,它不能顯示地被調用,SQL Server 允許為 INSERT、UPDATE、DELETE 創(chuàng)建觸發(fā)器,當在表(視圖)中插入、更新、刪除記錄時,觸發(fā)一個或一系列 T-SQL 語句。創(chuàng)建觸發(fā)器通常有兩種方式,一種是使用企業(yè)管理器創(chuàng)建觸發(fā)器,另一種是使用T-SQ

5、L代碼創(chuàng)建觸發(fā)器,語法格式,語法格式為:CREATE TRIGGER 觸發(fā)器名稱ON 表名FOR INSERT、UPDATE 或 DELETEAST-SQL 語句,,觸發(fā)器示例一 CREATE TRIGGER [dbo].[InsertLR] ON [dbo].[LeaveRecord] FOR INSERTAS BEGINSET NOCOUNT ON;declare @RecordID intde

6、clare @EmpID int select @RecordID=RecordID,@EmpID=EmpID from insertedINSERT INTO dbo.LEAVE_CHECK(leave_bill_id,leave_proposerid,check_employee_level,check_type)values(@RecordID,@EmpID,5,1)END,ADO.NET事務,ado.net事務專門用于操

7、作數據庫時,保持數據一致性,如:學生表與班級表,每增加一名學生,便要在班級表的總人數列上增加一人。如果學生有一名退學,便要在班級表總人數列中減去一人。 為了保持兩張表數據的一致性??梢允褂檬聞諏ζ溥M行處理。使用事務處理要用到名稱空間。,,SqlTransaction mytrans; // mytrans為事務類對象 SqlCommand comm = conn.CreateCommand();

8、 mytrans = conn.BeginTransaction();//連接類對象的BeginTransaction()方法 comm.Transaction = mytrans;// 命令類的Transaction屬性,UML對象時序圖講解,,,數據庫共用類 :方法一. ExecuteNonQuery,public static int ExecuteNonQuery(string connectio

9、nString, CommandType cmdType, string cmdText, params SqlParameter[] commandParameters) { SqlCommand cmd = new SqlCommand(); using (SqlConnection conn = new SqlConnection(connectionString))

10、 { PrepareCommand(cmd, conn, null, cmdType, cmdText, commandParameters); int val = cmd.ExecuteNonQuery(); cmd.Parameters.Clear(); return val;

11、 } },方法二. ExecuteNonQuery,public static int ExecuteNonQuery(SqlTransaction trans, CommandType cmdType, string cmdText, params SqlParameter[] commandParameters) { SqlCommand cmd = new

12、SqlCommand(); PrepareCommand(cmd, trans.Connection, trans, cmdType, cmdText, commandParameters); int val = cmd.ExecuteNonQuery(); cmd.Parameters.Clear(); return val;

13、 },方法三. PrepareCommand,private static void PrepareCommand(SqlCommand cmd, SqlConnection conn, SqlTransaction trans, CommandType cmdType, string cmdText, SqlParameter[] cmdParms) { if (conn.State != C

14、onnectionState.Open) conn.Open(); cmd.Connection = conn; cmd.CommandText = cmdText; if (trans != null) cmd.Transaction = trans; cmd.CommandT

15、ype = cmdType; if (cmdParms != null) { foreach (SqlParameter parm in cmdParms) cmd.Parameters.Add(parm); } },方法四. ExecuteScalar,public stati

16、c object ExecuteScalar(string connectionString, CommandType cmdType, string cmdText, params SqlParameter[] commandParameters) { SqlCommand cmd = new SqlCommand(); using (SqlConnection conn

17、ection = new SqlConnection(connectionString)) { PrepareCommand(cmd, connection, null, cmdType, cmdText, commandParameters); object val = cmd.ExecuteScalar(); cm

18、d.Parameters.Clear(); return val; } },方法五. ExecuteReader,public static SqlDataReader ExecuteReader(string connectionString, CommandType cmdType, string cmdText, params SqlParameter[] c

19、ommandParameters) { SqlCommand cmd = new SqlCommand(); SqlConnection conn = new SqlConnection(connectionString); try { PrepareCommand(cmd, conn, nul

20、l, cmdType, cmdText, commandParameters); SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection); cmd.Parameters.Clear(); return rdr; }

21、 catch { conn.Close(); throw; } } },數據庫操作類 :方法一. GetLeave,public int GetLeave(int Inputday) { SqlParameter[] param ={ new SqlPara

22、meter("@inputDay", SqlDbType.Int) }; param[0].Value = Inputday; string sqlSelect = "selConfigLeave"; int row=Convert.ToInt32(SqlHelper.ExecuteScalar(connectionstr,C

23、ommandType.StoredProcedure,sqlSelect,param)); return row; },方法二. GetLC。,public int GetLC(int LC) { SqlParameter[] param ={ new SqlParameter("@LC", SqlDbType.Int) };

24、 param[0].Value = LC; string sqlSelect = "select check_employee_level from dbo.LEAVE_CHECK where leave_bill_id=@LC"; int row = Convert.ToInt32(SqlHelper.ExecuteScalar(connectionstr

25、, CommandType.Text, sqlSelect, param)); return row; },方法三. updateApprove,public int updateApprove(int leaveid, int check_type) { SqlParameter[] param ={ new SqlParamete

26、r("@leaveid", SqlDbType.Int), new SqlParameter("@check_type", SqlDbType.Int) }; param[0].Value = leaveid; param[1].Value = check_type; strin

27、g sqlUpdate = "updateLC"; return SqlHelper.ExecuteNonQuery(connectionstr, CommandType.StoredProcedure, sqlUpdate, param); },方法四. InsertLeaveRecord,public int InsertLeaveRecord(LeaveRecordInf

28、o LRInfo) { SqlParameter[] param ={ new SqlParameter("@EmpID", SqlDbType.Int), new SqlParameter("@LeaveTypeID", SqlDbType.Int), new

29、SqlParameter("@BeginDate", SqlDbType.DateTime), new SqlParameter("@EndDate", SqlDbType.DateTime)}; param[0].Value = LRInfo.EmpID; param[1].Value = LRInfo.LeaveTy

30、peID; param[2].Value = LRInfo.BeginDate; param[3].Value = LRInfo.EndDate; string sqlInsert = "insert into dbo.LeaveRecord(EmpID,LeaveTypeID,BeginDate,EndDate,LeaveState)values(@Em

31、pID,@LeaveTypeID,@BeginDate,@EndDate,1)"; return SqlHelper.ExecuteNonQuery(connectionstr, CommandType.Text, sqlInsert, param); },方法五. GetEmpName,public List GetEmpName() { Lis

32、t ListEmp = new List(); EmployeeInfo emp = null; string sqlSelect = "select EmpID, EmployeeName from dbo.Employee"; SqlDataReader dr = SqlHelper.ExecuteReader(connectionstr,

33、CommandType.Text, sqlSelect, null); while (dr.Read()) { emp = new EmployeeInfo(dr.GetInt32(0), dr.GetString(1)); ListEmp.Add(emp); } return

34、ListEmp; },六.GetLeaveType,public List GetLeaveType() { List ListTY = new List(); LeaveTypeInfo LYInfo = null; string sqlSelect = "SELECT LeaveTypeID,LeaveType FROM

35、 dbo.LeaveType"; SqlDataReader dr = SqlHelper.ExecuteReader(connectionstr, CommandType.Text, sqlSelect, null); while (dr.Read()) { LYInfo = new LeaveTypeInfo(dr.Ge

36、tInt32(0), dr.GetString(1)); ListTY.Add(LYInfo); } return ListTY; },方法七. GetGETLeaveALL,public DataTable GetGETLeaveALL(int Empid) { DataTable dt = new

37、DataTable(); SqlParameter[] param ={ new SqlParameter("@empid", SqlDbType.Int) }; param[0].Value = Empid; string sqlselect = "GetLeave"; SqlDataReader d

38、r = SqlHelper.ExecuteReader(connectionstr, CommandType.StoredProcedure, sqlselect, param); dt.Load(dr, LoadOption.OverwriteChanges); return dt; },方法八. UserCheck。,public bool UserCheck(stri

39、ng username, string userpassword, ref int iEmpID, ref int DutyID) { string sqlselect="Pr_GetLogin"; SqlParameter[] param ={ new SqlParameter("@EmpName", Sq

40、lDbType.VarChar, 20), new SqlParameter("@Password", SqlDbType.VarChar, 50) }; param[0].Value=username; param[1].Value=userpassword; SqlDataReader dr=S

41、qlHelper.ExecuteReader(connectionstr,CommandType.StoredProcedure,sqlselect,param); if (dr.Read()) { iEmpID = Convert.ToInt32(dr["EmpID"].ToString());

42、 DutyID = Convert.ToInt32(dr["DutyID"].ToString()); return true; } else { return false; } },練習題,編程實

43、現(xiàn)以下業(yè)務需求: 1、公司購物要實現(xiàn)逐級審批制度,根據購物金額大小由低向高逐級審批。購物金額在500元以內,由項目經理審批;購物金額在501元至1000元之間由部長審批; 購物金額在1001元至5000元由總經理審批;購物金額在5001元以上由董事長審批。,,2、學院規(guī)定了對違紀學生的處分條例,對違紀學生組織實施處分要求由低向高逐級申報。學生曠課50節(jié)以內,由系部給予違紀學生警告處分;曠課51節(jié)至150節(jié),由院學生給予違紀學生記

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論