自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

教你輕松學(xué)會(huì)SQL Server記錄輪班的技巧

數(shù)據(jù)庫(kù) SQL Server
SQL Server記錄輪班是一種在平時(shí)的工作中很實(shí)用的操作技巧,下文中我將通過(guò)實(shí)例分析,為大家介紹SQL Server記錄輪班的技巧。

SQL Server記錄輪班的技巧:

例:公司員工采取三個(gè)輪班制度:凌晨0:00到早上8:00為***班,早上8:00到下午4:00為第二班,下午4:00到晚上12:00為第三班。

員工使用電子時(shí)鐘進(jìn)行簽名,這種電子簽名可以自動(dòng)將記錄添加到SQL Server數(shù)據(jù)庫(kù)中。但是,有時(shí)候,需要增加一個(gè)夜班;即使這個(gè)輪班發(fā)生在第二天,它仍然會(huì)被認(rèn)為是第三班。

你也許希望根據(jù)輪班對(duì)記錄進(jìn)行分組,但是在你的計(jì)劃中會(huì)有兩個(gè)非常令人頭痛的問(wèn)題:

(1)不是所有的雇員都是按時(shí)到達(dá)的;

(2)有時(shí)候員工工作的時(shí)間會(huì)比他們的一個(gè)輪班的時(shí)間長(zhǎng)一些。

為了能在你的列表中得到正確的分組,你必須假設(shè)所有的員工能在一個(gè)輪班的開(kāi)始和結(jié)束時(shí)間之間的任意時(shí)間開(kāi)始工作。

使用CASE語(yǔ)句是一種解決辦法。Listing A中的SQL語(yǔ)句告訴我們,在創(chuàng)建測(cè)試表沒(méi)有錯(cuò)誤的情況下,它是如何工作的。

為了使程序代碼完全準(zhǔn)確的運(yùn)行,你需要在時(shí)間的小窗口中得到每一個(gè)輪班的開(kāi)始時(shí)間和下一個(gè)輪班的結(jié)束時(shí)間。在剛才的例子中,你可以用'15:59:59.123'這個(gè)值代替@StartTime,然后再重新運(yùn)行代碼。這時(shí)候,你必須在每一個(gè)輪班結(jié)束的分界點(diǎn)上增加999毫秒。

解決方案

這個(gè)例子假設(shè)輪班時(shí)間從來(lái)沒(méi)有改變過(guò),但是如果改變了輪班時(shí)間該怎么辦呢?你必須仿照這個(gè)例子并根據(jù)改變了的時(shí)間寫(xiě)出所有的代碼。

一個(gè)更好一點(diǎn)的主意就是,針對(duì)我們的輪班創(chuàng)建一個(gè)表來(lái)調(diào)用Shifts的開(kāi)始時(shí)間和結(jié)束時(shí)間。在這個(gè)表中,你可以修改Case語(yǔ)句來(lái)查找StopTime列。


Listing B中包含了創(chuàng)建Shifts表并向該表中增加記錄的代碼。代碼在一個(gè)輪班中設(shè)置了時(shí)間后,這樣使代碼看上去既簡(jiǎn)單又靈活:


DECLARE @StartTime VARCHAR(20)

SET @StartTime ='22:59:59'

SELECT*** ShiftName FROM ShiftWork.Shifts

WHERE Shifts.StartTime <= @StartTime

ORDERBY StartTime DESC

我之所以要將輪班記錄進(jìn)行降序排列,是為了避免第三個(gè)輪班的邊界問(wèn)題。我將用一些測(cè)試案例來(lái)論證我的結(jié)論,這些內(nèi)容你可以在Listing C中看到。

實(shí)際上,你可以將這個(gè)邏輯應(yīng)用到TemeCards表的記錄中去,而不需要?jiǎng)?chuàng)建另外的表,也就不需要在表中增加數(shù)據(jù)了。我同樣使用一個(gè)簡(jiǎn)單的變量來(lái)論證我的邏輯。

相信通過(guò)實(shí)例的分析不難理解,比較單單的通過(guò)理論介紹要容易很多,希望學(xué)過(guò)之后對(duì)大家能夠有所幫助。

【編輯推薦】

  1. 解析SQL Server中數(shù)據(jù)庫(kù)快照的工作原理
  2. 教你如何利用SQL Server保護(hù)數(shù)據(jù)
  3. 實(shí)現(xiàn)Standby SQL Server 數(shù)據(jù)庫(kù)的方法
責(zé)任編輯:迎迎 來(lái)源: 賽迪網(wǎng)
相關(guān)推薦

2010-07-05 12:21:57

SQL Server記

2010-10-21 15:57:37

SQL Server無(wú)

2010-08-09 09:25:23

SQL Server鏡

2010-12-21 09:47:45

SQL Server

2010-11-10 11:27:40

SQL Server重

2022-07-25 11:25:42

Linux自動(dòng)化技巧

2021-03-09 10:08:15

Linux 自動(dòng)化操作系統(tǒng)

2022-01-27 13:23:15

Linux技巧命令

2022-11-16 09:04:36

SQL查詢(xún)SELECT

2010-09-14 13:22:51

sql server備

2010-07-21 11:26:07

SQL Server

2009-04-28 13:48:04

SQL Server群集技巧

2009-04-16 15:26:32

Sql Server記錄總數(shù)聚簇索引

2010-09-01 17:19:49

SQL刪除TABLE

2011-03-31 10:52:13

2012-04-06 10:13:08

SQLSQL Server

2009-12-23 15:55:53

Linux權(quán)限管理

2010-09-27 15:10:12

SQL Server

2010-12-06 09:26:23

SQL Server

2009-12-02 13:39:34

Suse啟動(dòng)cron
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)