版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、第11章 自定義員工請 假審批工作流,大連理工大學(xué)電子音像出版社 出版,第11章 自定義員工請假審批工作流,目的和要求:,掌握視圖的定義與使用掌握觸發(fā)器的定義與使用掌握 ADO.NET事務(wù)的定義與使用,重點(diǎn)和難點(diǎn):,觸發(fā)器的定義與使用ADO.NET事務(wù)的定義與使用,模塊業(yè)務(wù)描述,第一級審批權(quán)限: 如果請假10天以上, 由員工提交請假申報(bào),經(jīng)教研室主任批準(zhǔn)后,分別經(jīng)系主任、副院長、院長逐級審批后,最后
2、由董事長批準(zhǔn)終止流程。第二級審批權(quán)限:如果請假7-10天, 由員工提交請假申報(bào),經(jīng)教研室主任批準(zhǔn)后,分別由系主任、副院長逐級審批, 最后由院長審批終止流程。第三級審批權(quán)限:如果請假3-7天, 由員工提交請假申報(bào),經(jīng)教研室主任批準(zhǔn)后,再系主任審批,最后由副院長審批終止流程。第四級審批權(quán)限: 如果請假1-3天, 由員工提交請假申報(bào),教研室主任批準(zhǔn),呈送經(jīng)系主任審批終止流程。第五級審批權(quán)限: 如果請假1天,由員工提交請假申報(bào),教研室主
3、任批準(zhǔn)終止流程。,模塊 UML圖設(shè)計(jì),,,模塊界面設(shè)計(jì),基礎(chǔ)知識,視圖定義 視圖是一張?zhí)摂M表,它數(shù)據(jù)來源于基本表。優(yōu)點(diǎn)便于數(shù)據(jù)的操作,能將幾張表的中集中起來,可以簡化操作 示例一: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ā)器是一種特殊的存儲過程,它不能顯示地被調(diào)用,SQL Server 允許為 INSERT、UPDATE、DELETE 創(chuàng)建觸發(fā)器,當(dāng)在表(視圖)中插入、更新、刪除記錄時(shí),觸發(fā)一個(gè)或一系列 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事務(wù),ado.net事務(wù)專門用于操
7、作數(shù)據(jù)庫時(shí),保持?jǐn)?shù)據(jù)一致性,如:學(xué)生表與班級表,每增加一名學(xué)生,便要在班級表的總?cè)藬?shù)列上增加一人。如果學(xué)生有一名退學(xué),便要在班級表總?cè)藬?shù)列中減去一人。 為了保持兩張表數(shù)據(jù)的一致性。可以使用事務(wù)對其進(jìn)行處理。使用事務(wù)處理要用到名稱空間。,,SqlTransaction mytrans; // mytrans為事務(wù)類對象 SqlCommand comm = conn.CreateCommand();
8、 mytrans = conn.BeginTransaction();//連接類對象的BeginTransaction()方法 comm.Transaction = mytrans;// 命令類的Transaction屬性,UML對象時(shí)序圖講解,,,數(shù)據(jù)庫共用類 :方法一. 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; } } },數(shù)據(jù)庫操作類 :方法一. 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; } },練習(xí)題,編程實(shí)
43、現(xiàn)以下業(yè)務(wù)需求: 1、公司購物要實(shí)現(xiàn)逐級審批制度,根據(jù)購物金額大小由低向高逐級審批。購物金額在500元以內(nèi),由項(xiàng)目經(jīng)理審批;購物金額在501元至1000元之間由部長審批; 購物金額在1001元至5000元由總經(jīng)理審批;購物金額在5001元以上由董事長審批。,,2、學(xué)院規(guī)定了對違紀(jì)學(xué)生的處分條例,對違紀(jì)學(xué)生組織實(shí)施處分要求由低向高逐級申報(bào)。學(xué)生曠課50節(jié)以內(nèi),由系部給予違紀(jì)學(xué)生警告處分;曠課51節(jié)至150節(jié),由院學(xué)生給予違紀(jì)學(xué)生記
溫馨提示
- 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)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 基于WF工作流自定義活動的研究與應(yīng)用.pdf
- 港口企業(yè)工作流自定義平臺的設(shè)計(jì)與實(shí)現(xiàn).pdf
- 企業(yè)協(xié)同辦公自定義工作流的系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn).pdf
- 基于.net與ajax的自定義工作流的研究與實(shí)現(xiàn)
- 自定義工作流模型的應(yīng)用及其圖形化研究.pdf
- 中小企業(yè)自定義工作流引擎的設(shè)計(jì)與實(shí)現(xiàn).pdf
- 面向?qū)徟鷺I(yè)務(wù)的Web自定義工作流模型研究與實(shí)現(xiàn).pdf
- 房屋缺陷管理系統(tǒng)自定義工作流技術(shù)研究與實(shí)現(xiàn).pdf
- autocad自定義線形
- 自定義菜單.txt
- 基于Activiti5的自定義工作流系統(tǒng)的研究與實(shí)現(xiàn).pdf
- 《flash自定義函數(shù)》教案
- 自定義類加載器
- 一種可自定義工作流的辦公管理系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn).pdf
- 自定義.~(1).LibPkg.Zip
- 自定義.~(1).PcbLib.Zip
- 自定義.~(2).PcbLib.Zip
- win快速啟動欄自定義
- 存儲過程與自定義函數(shù)
- 湘源圖則自定義
評論
0/150
提交評論