目标: 利用Mysql定时任务,触发器生成工厂日历
问题描述: 将日期分为三种类别 
    ·法定节假日     ·公休
      
     ·工作日
 现在能对十月一日、五月一日、元旦这种公历法定假日予以处理,但是不能处理诸如春节、清明节这样的法定假日。典型情况:
  如何判断指定的日期是不是"春节"? 

解决方案 »

  1.   

    以下转自 http://blog.csdn.net/tianxiajianling/article/details/7633003
    下面是经过整理的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位搭配使用。由此可以看出,阴历的规律性是很差的。要推算阴历,必需基于查表的算法,具体的数据结构安排,可以根据不同的语言作灵活的安排。
    请大家帮帮忙,请随意谈谈自己的看法。主大人貌似不在线...
      

  2.   

    版主大人,正常情况下mysql能不能生成车间日历?常规的思路是什么?能不能指导下?多谢。
      

  3.   

    SAP是这样做的,划分为一般日历,节假日日历和工厂日历。国家对于基于传统的法定节假日和新中国成立以后的节假日放假规则是一样的。只不过由于民国后使用了太阳历。自商朝形成的太阴历已经非官方推荐了。
    预期是提供一个默认的工作日历,当然允许用户修改(一般不需要)。
    现在已经有所突破了,等写完后。还请版主大人帮忙调整下效率。基本思路是基于查表来做(1901-2050)。没有通用的计算公式。不过貌似在清朝后期有人研究过,人名忘记了。稍微晚一点再把此类的相关资料整理下。
      

  4.   

    以下是150年(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因为清明节是不太容易计算的,所以决定用查表的方法来做。传统的计算方法是:以立春日,加上二十四节气来计算(不精确,达不到要求)。