quartz的时间配置
字符说明
顺序
从左到右的说明:* * * * * * * (秒>分>时>天>月>周>年)
含义 是否必填 允许填写的值 允许的通配符
秒 是 0-59 - * /
分 是 0-59 - * /
小时 是 0-23 - * /
日 是 1-31 - * ? / L W
月 是 1-12 - * /
周 是 1-7or SUN-SAT - * ? / L #
年 否 不填或1970-2099 - * /
通配符说明
-:表示区间如小时的7-23表示从7点到23点
*:表示所有整数值如在小时上填*表示每小时
?:表示不指定值即不关心当前设置的值如要在每月的10号触发一个操作,但不关心是周几,所以需要周位置的那个字段设置为"?" 具体设置为 0 0 0 10 * ?
/:表示递增触发如在小时上设置7/1,表示从7点开始,每隔1小时触发一次
L:表示最后如在日上设置L,表示最后一天
W:表示离指定指定日期的最后一个工作日(周一到周五)如在日字段上设置"15W",表示离每月15号最近的那个工作日触发。如果15号正好是周六,则找最近的周五(14号)触发, 如果15号是周未,则找最近的下周一(16号)触发.如果15号正好在工作日(周一至周五),则就在该天触发。(注,"W"前只能设置具体的数字,不允许区间"-"),在日字段写LW,表示在每月的最后一个工作日触发
#:表示每月的第几个周几如例如在周字段上设置"6#3"表示在每月的第三个周六.注意如果指定"#5",正好第五周没有周六,则不会触发该配置
常用示例
0 0 1/3 * * ? 每天从1点开始,每隔三小时触发一次
0 0 12 * * ? 每天12点触发
0 15 10 ? * * 每天10点15分触发
0 15 10 * * ? 每天10点15分触发
0 15 10 * * ? * 每天10点15分触发
0 15 10 * * ? 2005 2005年每天10点15分触发
0 * 14 * * ? 每天下午的 2点到2点59分每分触发
0 0/5 14 * * ? 每天下午的 2点到2点59分(整点开始,每隔5分触发)
0 0/5 14,18 * * ? 每天下午的 2点到2点59分(整点开始,每隔5分触发)
每天下午的 18点到18点59分(整点开始,每隔5分触发)
0 0-5 14 * * ? 每天下午的 2点到2点05分每分触发
0 10,44 14 ? 3 WED 3月分每周三下午的 2点10分和2点44分触发 (特殊情况,在一个时间设置里,执行两次或 两次以上的情况)
0 59 2 ? * FRI 每周5凌晨2点59分触发;
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 从2002年到2005年每月最后一周的星期五的10点15分触发
0 15 10 ? * 6#3 每月的第三周的星期五开始触发
0 0 12 1/5 * ? 每月的第一个中午开始每隔5天触发一次
0 11 11 11 11 ? 每年的11月11号 11点11分触发(光棍节)
正则表达式
语法
单个符号
英文的点(.):表示匹配单个字符如t.0
中括号[]:表示匹配指定的单个字符如t[abcd]n
或 |:表示匹配其中的一项如t(a|b|c|dd)n
表示匹配次数的符号
image.png
否^:表示不想匹配的字符如^x
快捷字符
\d 表示数字字符匹配,等效于[0-9]
\D 表示非数字字符匹配,等效于[^0-9]
\s 表示空白字符匹配,包括空格、制表符、换页符等。与 [ \f\n\r\t\v] 等效
\S 表示非空白字符匹配
\w 表示任何字类字符匹配,包括下划线。与"[A-Za-z0-9_]"等效。
\W 表示与任何非单词字符匹配
参考链接: https://blog.csdn.net/weixin_43860260/article/details/91417485
自定义函数模板
--测试实例
CREATE OR REPLACE FUNCTION public.tmp_test(testId bigint)
RETURNS INTEGER AS
$BODY$
DECLARE
testRecordCursor REFCURSOR;
testRecord t_test;
testId BIGINT;
BEGIN
RAISE NOTICE '主键id:%', testId;
testId := 123;
SELECT test_id INTO testId FROM t_test;
SELECT * INTO testRecord FROM t_test;
testId := testRecord.test_id;
IF NOT FOUND THEN
RAISE EXCEPTION 'id:%的记录不存在', testId;
END IF;
--插入
INSERT INTO t_test (
id,
name
)
VALUES
(
1,
'2'
)
RETURNING * INTO testRecord;
OPEN testRecordCursor FOR SELECT * FROM t_test;
LOOP
FETCH testRecordCursor INTO testRecord;
IF NOT FOUND THEN
RAISE NOTICE '没有找到记录';
EXIT;
END IF;
RAISE NOTICE '数据处理';
END LOOP;
RETURN 1;
END
$BODY$
LANGUAGE plpgsql VOLATILE
COST 100;
网友评论