版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
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. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 基于WF工作流自定義活動的研究與應用.pdf
- 港口企業(yè)工作流自定義平臺的設計與實現(xiàn).pdf
- 企業(yè)協(xié)同辦公自定義工作流的系統(tǒng)設計與實現(xiàn).pdf
- 基于.net與ajax的自定義工作流的研究與實現(xiàn)
- 自定義工作流模型的應用及其圖形化研究.pdf
- 中小企業(yè)自定義工作流引擎的設計與實現(xiàn).pdf
- 面向審批業(yè)務的Web自定義工作流模型研究與實現(xiàn).pdf
- 房屋缺陷管理系統(tǒng)自定義工作流技術研究與實現(xiàn).pdf
- autocad自定義線形
- 自定義菜單.txt
- 基于Activiti5的自定義工作流系統(tǒng)的研究與實現(xiàn).pdf
- 《flash自定義函數》教案
- 自定義類加載器
- 一種可自定義工作流的辦公管理系統(tǒng)的設計與實現(xiàn).pdf
- 自定義.~(1).LibPkg.Zip
- 自定義.~(1).PcbLib.Zip
- 自定義.~(2).PcbLib.Zip
- win快速啟動欄自定義
- 存儲過程與自定義函數
- 湘源圖則自定義
評論
0/150
提交評論