quartz cron觸發器表示式

2021-05-25 14:09:18 字數 2455 閱讀 2800

字段 允許值 允許的特殊字元

秒 0-59 , - * /

分 0-59 , - * /

小時 0-23 , - * /

日期 1-31 , - * ? / l w c

月份 1-12 或者 jan-dec , - * /

星期 1-7 或者 sun-sat , - * ? / l c #

年(可選) 留空, 1970-2099 , - * /

「*」字元被用來指定所有的值。如:」*「在分鐘的字段域裡表示「每分鐘」。

「?」字元只在日期域和星期域中使用。它被用來指定「非明確的值」。當你需要通過在這兩個域中的乙個來指定一些東西的時候,它是有用的。看下面的例子你就會明白。

月份中的日期和星期中的日期這兩個元素時互斥的一起應該通過設定乙個問號(?)來表明不想設定那個字段。

「-」字元被用來指定乙個範圍。如:「10-12」在小時域意味著「10點、11點、12點」。

「,」字元被用來指定另外的值。如:「mon,wed,fri」在星期域裡表示」星期

一、星期

三、星期五」。

「/」字元用於指定增量。如:「0/15」在秒域意思是沒分鐘的0,15,30和45秒。「5/15」在分鐘域表示沒小時的5,20,35和50。符號「*」在「/」前面(如:*/10)等價於0在「/」前面(如:0/10)。記住一條本質:表示式的每個數值域都是乙個有最大值和最小值的集合,如:秒域和分鐘域的集合是0-59,日期域是1-31,月份域是1-12。字元「/」可以幫助你在每個字元域中取相應的數值。如:「7/6」在月份域的時候只有當7月的時候才會觸發,並不是表示每個6月。

l是『last』的省略寫法可以表示day-of-month和day-of-week域,但在兩個欄位中的意思不同,例如day-of-month域中表示乙個月的最後一天。如果在day-of-week域表示『7』或者『sat』,如果在day-of-week域中前面加上數字,它表示乙個月的最後幾天,例如『6l』就表示乙個月的最後乙個星期五。

字元「w」只允許日期域出現。這個字元用於指定日期的最近工作日。例如:如果你在日期域中寫 「15w」,表示:這個月15號最近的工作日。所以,如果15號是週六,則任務會在14號觸發。如果15好是週日,則任務會在周一也就是16號觸發。如果是在日期域填寫「1w」即使1號是週六,那麼任務也只會在下周一,也就是3號觸發,「w」字元指定的最近工作日是不能夠跨月份的。字元「w」只能配合乙個單獨的數值使用,不能夠是乙個數字段,如:1-15w是錯誤的。

「l」和「w」可以在日期域中聯合使用,lw表示這個月最後一周的工作日。

字元「#」只允許在星期域中出現。這個字元用於指定本月的某某天。例如:「6#3」表示本月第三週的星期五(6表示星期五,3表示第三週)。「2#1」表示本月第一周的星期一。「4#5」表示第五周的星期三。

字元「c」允許在日期域和星期域出現。這個字元依靠乙個指定的「日曆」。也就是說這個表示式的值依賴於相關的「日曆」的計算結果,如果沒有「日曆」關聯,則等價於所有包含的「日曆」。如:日期域是「5c」表示關聯「日曆」中第一天,或者這個月開始的第一天的後5天。星期域是「1c」表示關聯「日曆」中第一天,或者星期的第一天的後1天,也就是週日的後一天(周一)。

表示式舉例:

"0 0 12 * * ?" 每天中午12點觸發

"0 15 10 ? * *" 每天上午10:15觸發

"0 15 10 * * ?" 每天上午10:15觸發

"0 15 10 * * ? *" 每天上午10:15觸發

"0 15 10 * * ? 2005" 2023年的每天上午10:15觸發

"0 * 14 * * ?" 在每天下午2點到下午2:59期間的每1分鐘觸發

"0 0/5 14 * * ?" 在每天下午2點到下午2:55期間的每5分鐘觸發

"0 0/5 14,18 * * ?" 在每天下午2點到2:55期間和下午6點到6:55期間的每5分鐘觸發

"0 0-5 14 * * ?" 在每天下午2點到下午2:05期間的每1分鐘觸發

"0 10,44 14 ? 3 wed" 每年三月的星期三的下午2:10和2:44觸發

"0 15 10 ? * mon-fri" 周一至周五的上午10:15觸發

"0 15 10 15 * ?" 每月15日上午10:15觸發

"0 15 10 l * ?" 每月最後一日的上午10:15觸發

"0 15 10 ? * 6l" 每月的最後乙個星期五上午10:15觸發

"0 15 10 ? * 6l 2002-2005" 2023年至2023年的每月的最後乙個星期五上午10:15觸發

"0 15 10 ? * 6#3" 每月的第三個星期五上午10:15觸發

0 6 * * * 每天早上6點

0 */2 * * * 每兩個小時

0 23-7/2,8 * * * 晚上11點到早上8點之間每兩個小時,早上八點

0 11 4 * 1-3 每個月的4號和每個禮拜的禮拜一到禮拜三的早上11點

0 4 1 1 * 1月1日早上4點

觸發器 mysql觸發器

觸發器是一種特殊的儲存過程,它在插入 刪除或修改特定表中的資料時觸發執行,它比資料庫本身標準的功能有更精細和更複雜的資料控制能力。和儲存過程一樣,很少使用。1 觸發器的作用 2 建立觸發器 建立測試環境 mysql create database test db query ok,1 row aff...

觸發器(五 復合觸發器)

oracle11g開始提供了一種復合觸發器,簡單的說就是支援把語句級和行級觸發器組合在一起。實際應用場景不多,這裡就做個記錄。與單個觸發器語法有所區別 1.單個觸發器的頭部是 before after 動作 on 物件 for 觸發級別 而組合觸發器的頭部是 for 動作 on 物件 compoun...

mysql觸發器when MySQL觸發器

set quoted identifier on goset ansi nulls on goalter trigger trg risks on dbo.projectrisk for insert,update asbegin update projectrisk set classificat...