目标: 利用Mysql定时任务,触发器生成工厂日历
问题描述: 将日期分为三种类别
·法定节假日 ·公休
·工作日
现在能对十月一日、五月一日、元旦这种公历法定假日予以处理,但是不能处理诸如春节、清明节这样的法定假日。典型情况:
如何判断指定的日期是不是"春节"?
问题描述: 将日期分为三种类别
·法定节假日 ·公休
·工作日
现在能对十月一日、五月一日、元旦这种公历法定假日予以处理,但是不能处理诸如春节、清明节这样的法定假日。典型情况:
如何判断指定的日期是不是"春节"?
下面是经过整理的150年内的阴历数据:0x04bd8,0x04ae0,0x0a570,0x054d5,0x0d260,0x0d950,0x16554,0x056a0,0x09ad0,0x055d2,
0x04ae0,0x0a5b6,0x0a4d0,0x0d250,0x1d255,0x0b540,0x0d6a0,0x0ada2,0x095b0,0x14977,
0x04970,0x0a4b0,0x0b4b5,0x06a50,0x06d40,0x1ab54,0x02b60,0x09570,0x052f2,0x04970,
0x06566,0x0d4a0,0x0ea50,0x06e95,0x05ad0,0x02b60,0x186e3,0x092e0,0x1c8d7,0x0c950,
0x0d4a0,0x1d8a6,0x0b550,0x056a0,0x1a5b4,0x025d0,0x092d0,0x0d2b2,0x0a950,0x0b557,
0x06ca0,0x0b550,0x15355,0x04da0,0x0a5d0,0x14573,0x052d0,0x0a9a8,0x0e950,0x06aa0,
0x0aea6,0x0ab50,0x04b60,0x0aae4,0x0a570,0x05260,0x0f263,0x0d950,0x05b57,0x056a0,
0x096d0,0x04dd5,0x04ad0,0x0a4d0,0x0d4d4,0x0d250,0x0d558,0x0b540,0x0b5a0,0x195a6,
0x095b0,0x049b0,0x0a974,0x0a4b0,0x0b27a,0x06a50,0x06d40,0x0af46,0x0ab60,0x09570,
0x04af5,0x04970,0x064b0,0x074a3,0x0ea50,0x06b58,0x055c0,0x0ab60,0x096d5,0x092e0,
0x0c960,0x0d954,0x0d4a0,0x0da50,0x07552,0x056a0,0x0abb7,0x025d0,0x092d0,0x0cab5,
0x0a950,0x0b4a0,0x0baa4,0x0ad50,0x055d9,0x04ba0,0x0a5b0,0x15176,0x052b0,0x0a930,
0x07954,0x06aa0,0x0ad50,0x05b52,0x04b60,0x0a6e6,0x0a4e0,0x0d260,0x0ea65,0x0d530,
0x05aa0,0x076a3,0x096d0,0x04bd7,0x04ad0,0x0a4d0,0x1d0b6,0x0d250,0x0d520,0x0dd45,
0x0b5a0,0x056d0,0x055b2,0x049b0,0x0a577,0x0a4b0,0x0aa50,0x1b255,0x06d20,0x0ada0。要推算阴历,就要根据这些数据来推。上面共15行,每行10个数据。每个数据代表一年,从阳历1900.1.31日起,为第一个数据年的开始,即阳历1900.1.31=阴历0.1.1。150个数据可推150年的阴历,因此目前最大只能推算到2049年,以后的推导,还需要从天文台得到新的数据后才能推导,否则将出现误差。要推算阴历,关键是理解这些数据的意义。拿第一个数据来说,代表阳历1900.1.31为始的阴历0年,0x04bd8是5个16进制数,共20bit。 前4位,即0在这一年是润年时才有意义,它代表这年润月的大小月,为1则润大月,为0则润小月。
中间12位,即4bd,每位代表一个月,为1则为大月,为0则为小月。
最后4位,即8,代表这一年的润月月份,为0则不润。首4位要与末4位搭配使用。由此可以看出,阴历的规律性是很差的。要推算阴历,必需基于查表的算法,具体的数据结构安排,可以根据不同的语言作灵活的安排。
请大家帮帮忙,请随意谈谈自己的看法。主大人貌似不在线...
预期是提供一个默认的工作日历,当然允许用户修改(一般不需要)。
现在已经有所突破了,等写完后。还请版主大人帮忙调整下效率。基本思路是基于查表来做(1901-2050)。没有通用的计算公式。不过貌似在清朝后期有人研究过,人名忘记了。稍微晚一点再把此类的相关资料整理下。
年份 大小月(HEX) 闰月(4bit) 偏移 春节 端午 中秋 清明 立春
1901 4ae0 0 50 2.19 6.20 9.27 4.5 2.4
1902 a570 0 39 2.8 6.10 9.16 4.6 2.5
1903 5268 5 29 1.29 5.31 10.5. 4.6 2.5
1904 d260 0 47 2.16 6.18 10.5 4.5 2.5
1905 d950 0 35 2.4 6.7 9.13 4.5 2.5
1906 6aa8 4 25 1.25 6.26 10.2 4.6 2.5
1907 56a0 0 44 2.13 6.15 9.22 4.6 2.5
1908 9ad0 0 33 2.2 6.3 9.10 4.5 2.5
1909 4ae8 2 22 1.22 6.22 9.28 4.5 2.4
1910 4ae0 0 41 2.10 6.11 9.18 4.6 2.5
1911 a4d8 6 30 1.30 6.1 10.6 4.6 2.5
1912 a4d0 0 49 2.18 6.19 9.25 4.5 2.5
1913 d250 0 37 2.6 6.9 9.15 4.5 2.4
1914 d528 5 26 1.26 5.29 10.4 4.5 2.4
1915 b540 0 45 2.14 6.17 9.23 4.6 2.5
1916 d6a0 0 34 2.3 6.5 9.12 4.5 2.5
1917 96d0 2 23 1.23 6.23 9.30 4.5 2.4
1918 95b0 0 42 2.11 6.13 9.19 4.5 2.4
1919 49b8 7 32 2.1 6.2 10.8 4.6 2.5
1920 4970 0 51 2.20 6.20 9.26 4.5 2.5
1921 a4b0 0 39 2.8 6.10 9.16 4.5 2.4
1922 b258 5 28 1.28 5.31 10.5 4.6 2.4
1923 6a50 0 47 2.16 6.18 9.25 4.6 2.5
1924 6d40 0 36 2.5 6.6 9.13 4.5 2.5
1925 ada8 4 24 1.24 6.25 10.2 4.5 2.4
1926 2b60 0 44 2.13 6.14 9.21 4.5 2.4
1927 9570 0 33 2.2 6.4 9.10 4.6 2.5
1928 4978 2 23 1.23 6.22 9.28 4.5 2.5
1929 4970 0 41 2.10 6.11 9.17 4.5 2.4
1930 64b0 6 30 1.30 6.1 10.6 4.5 2.4
1931 d4a0 0 48 2.17 6.20 9.26 4.6 2.5
1932 ea50 0 37 2.6 6.8 9.15 4.5 2.5
1933 6d48 5 26 1.26 5.28 10.4 4.5 2.4
1934 5ad0 0 45 2.14 6.16 9.23 4.5 2.4
1935 2b60 0 35 2.4 6.5 9.12 4.6 2.5
1936 9370 3 24 1.24 6.23 9.30 4.5 2.5
1937 92e0 0 42 2.11 6.13 9.19 4.5 2.4
1938 c968 7 31 1.31 6.2 10.8 4.5 2.4
1939 c950 0 50 2.19 6.21 9.27 4.6 2.5
1940 d4a0 0 39 2.8 6.10 9.16 4.5 2.5
1941 da50 6 27 1.27 5.30 10.5 4.5 2.4
1942 b550 0 46 2.15 6.18 9.24 4.5 2.4
1943 56a0 0 36 2.5 6.7 9.14 4.6 2.5
1944 aad8 4 25 1.25 6.25 10.1 4.5 2.5
1945 25d0 0 44 2.13 6.14 9.20 4.5 2.4
1946 92d0 0 33 2.2 6.4 9.10 4.5 2.4
1947 c958 2 22 1.22 6.23 9.29 4.5 2.4
1948 a950 0 41 2.10 6.11 9.17 4.5 2.5
1949 b4a8 7 29 1.29 6.1 10.6 4.5 2.4
1950 6ca0 0 48 2.17 6.19 9.26 4.5 2.4
1951 b550 0 37 2.6 6.9 9.15 4.5 2.4
1952 55a8 5 27 1.27 5.28 10.3 4.5 2.5
1953 4da0 0 45 2.14 6.15 9.22 4.5 2.4
1954 a5b0 0 34 2.3 6.5 9.11 4.5 2.4
1955 52b8 3 24 1.24 6.24 9.30 4.5 2.4
1956 52b0 0 43 2.12 6.13 9.19 4.5 2.5
1957 a950 8 31 1.31 6.2 9.8 4.5 2.4
1958 e950 0 49 2.18 6.21 9.27 4.5 2.4
1959 6aa0 0 39 2.8 6.10 9.17 4.5 2.4
1960 ad50 6 28 1.28 5.29 10.5 4.5 2.5
1961 ab50 0 46 2.15 6.17 9.24 4.5 2.4
1962 4b60 0 36 2.5 6.6 9.13 4.5 2.4
1963 a570 4 25 1.25 6.25 10.2 4.5 2.4
1964 a570 0 44 2.13 6.14 9.20 4.5 2.5
1965 5260 0 33 2.2 6.4 9.10 4.5 2.4
1966 e930 3 21 1.21 6.23 9.29 4.5 2.4
1967 d950 0 40 2.9 6.12 9.18 4.5 2.4
1968 5aa8 7 30 1.30 5.31 10.6 4.5 2.5
1969 56a0 0 48 2.17 6.19 9.26 4.5 2.4
1970 96d0 0 37 2.6 6.8 9.15 4.5 2.4
1971 4ae8 5 27 1.27 5.28 10.3 4.5 2.4
1972 4ad0 0 46 2.15 6.15 9.22 4.5 2.5
1973 a4d0 0 34 2.3 6.5 9.11 4.5 2.4
1974 d268 4 23 1.23 6.24 9.30 4.5 2.4
1975 d250 0 42 2.11 6.14 9.20 4.5 2.4
1976 d528 8 31 1.31 6.2 10.8 4.4 2.5
1977 b540 0 49 2.18 6.21 9.27 4.5 2.4
1978 b6a0 0 38 2.7 6.10 9.17 4.5 2.4
1979 96d0 6 28 1.28 5.30 10.5 4.5 2.4
1980 95b0 0 47 2.16 6.17 9.23 4.4 2.5
1981 49b0 0 36 2.5 6.6 9.12 4.5 2.4
1982 a4b8 4 25 1.25 6.25 10.1 4.5 2.4
1983 a4b0 0 44 2.13 6.15 9.21 4.5 2.4
1984 b258 A 33 2.2 6.4 9.10 4.4 2.4
1985 6a50 0 51 2.20 6.22 9.29 4.5 2.4
1986 6d40 0 40 2.9 6.11 9.18 4.5 2.4
1987 ada0 6 29 1.29 5.31 10.7 4.5 2.4
1988 ab60 0 48 2.17 6.18 9.25 4.4 2.4
1989 9570 0 37 2.6 6.8 9.14 4.5 2.4
1990 4978 5 27 1.27 5.28 10.3 4.5 2.4
1991 4970 0 46 2.15 6.16 9.22 4.5 2.4
1992 64b0 0 35 2.4 6.5 9.11 4.4 2.4
1993 6a50 3 23 1.23 6.24 9.30 4.5 2.4
1994 ea50 0 41 2.10 6.13 9.20 4.5 2.4
1995 6b28 8 31 1.31 6.2 9.9 4.5 2.4
1996 5ac0 0 50 2.19 6.20 9.27 4.4 2.4
1997 ab60 0 38 2.7 6.9 9.16 4.5 2.4
1998 9368 5 28 1.28 5.30 10.5 4.5 2.4
1999 92e0 0 47 2.16 6.18 9.24 4.5 2.4
2000 c960 0 36 2.5 6.6 9.12 4.4 2.4
2001 d4a8 4 24 1.24 6.25 10.1 4.5 2.4
2002 d4a0 0 43 2.12 6.15 9.21 4.5 2.4
2003 da50 0 32 2.1 6.4 9.11 4.5 2.4
2004 5aa8 2 51 1.22 6.22 9.28 4.4 2.4
2005 56a0 0 40 2.9 6.11 9.18 4.5 2.4
2006 aad8 7 29 1.29 5.31 10.6 4.5 2.4
2007 25d0 0 49 2.18 6.19 9.25 4.5 2.4
2008 92d0 0 38 2.7 6.8 9.14 4.4 2.4
2009 c958 5 26 1.26 5.28 10.3 4.4 2.4
2010 a950 0 45 2.14 6.16 9.22 4.5 2.4
2011 b4a0 0 34 2.3 6.6 9.12 4.5 2.4
2012 b550 4 23 1.23 6.23 9.30 4.4 2.4
2013 ad50 0 41 2.10 6.12 9.19 4.4 2.4
2014 55a8 9 31 1.31 6.2 9.8 4.5 2.4
2015 4ba0 0 50 2.19 6.20 9.27 4.5 2.4
2016 a5b0 0 39 2.8 6.9 9.15 4.4 2.4
2017 52b8 6 28 1.28 5.30 10.4 4.4 2.3
2018 52b0 0 47 2.16 6.18 9.24 4.5 2.4
2019 a930 0 36 2.5 6.7 9.13 4.5 2.4
2020 74a8 4 25 1.25 6.25 10.1 4.4 2.4
2021 6aa0 0 43 2.12 6.14 9.21 4.4 2.3
2022 ad50 0 31 2.1 6.3 9.10 4.5 2.4
2023 4da8 2 22 1.22 6.22 9.29 4.5 2.4
2024 4b60 0 41 2.10 6.10 9.17 4.4 2.4
2025 a570 6 29 1.29 5.31 10.6 4.4 2.3
2026 a4e0 0 48 2.17 6.19 9.25 4.5 2.4
2027 d260 0 37 2.6 6.9 9.15 4.5 2.4
2028 e930 5 26 1.26 5.28 10.3 4.4 2.4
2029 d530 0 44 2.13 6.16 9.22 4.4 2.3
2030 5aa0 0 34 2.3 6.5 9.12 4.5 2.4
2031 6b50 3 23 1.23 6.24 10.1 4.5 2.4
2032 96d0 0 42 2.11 6.12 9.19 4.4 2.4
2033 4ae8 b 31 1.31 6.1 9.8 4.4 2.3
2034 4ad0 0 50 2.19 6.20 9.27 4.5 2.4
2035 a4d0 0 39 2.8 6.10 9.16 4.5 2.4
2036 d258 6 28 1.28 5.30 10.4 4.4 2.4
2037 d250 0 46 2.15 6.18 9.24 4.4 2.3
2038 d520 0 35 2.4 6.7 9.13 4.5 2.4
2039 daa0 5 24 1.24 5.27 10.2 4.5 2.4
2040 b5a0 0 43 2.12 6.14 9.20 4.4 2.4
2041 56d0 0 32 2.1 6.3 9.10 4.4 2.3
2042 4ad8 2 22 1.22 6.22 9.28 4.4 2.4
2043 49b0 0 41 2.10 6.11 9.17 4.5 2.4
2044 a4b8 7 30 1.30 5.31 10.6 4.4 2.4
2045 a4b0 0 48 2.17 6.19 9.25 4.4 2.3
2046 aa50 0 37 2.6 6.8 9.15 4.4 2.4
2047 b528 5 26 1.26 5.29 10.4 4.5 2.4
2048 6d20 0 45 2.14 6.15 9.22 4.4 2.4
2049 ada0 0 33 2.2 6.4 9.11 4.4 2.3
2050 55b0 3 23 1.23 6.23 9.30 4.4 2.3因为清明节是不太容易计算的,所以决定用查表的方法来做。传统的计算方法是:以立春日,加上二十四节气来计算(不精确,达不到要求)。