MySQL里求给定的时间是所在月份的第几个礼拜

来源:互联网 发布:男士祛痘洗面奶 知乎 编辑:程序博客网 时间:2024/05/01 22:54
Share 一个昨天写的函数。 目的是求给定的时间是所在月份的第几个礼拜。


[sql] view plaincopy
  1. DELIMITER $$  
  2.   
  3.   
  4.   
  5.   
  6. USE `t_girl`$$  
  7.   
  8.   
  9.   
  10.   
  11. DROP FUNCTION IF EXISTS `weekofmonth`$$  
  12.   
  13.   
  14.   
  15.   
  16. CREATE DEFINER=`root`@`localhost` FUNCTION `weekofmonth`(  
  17.     f_datetime DATETIME  
  18.     ) RETURNS INT(11)  
  19. BEGIN  
  20.    -- Created by ytt.  
  21.   
  22.   
  23.   
  24.   
  25.     DECLARE v_result INT;      
  26.     DECLARE v_weekno INT;  
  27.     SET v_weekno =   
  28.     CASE DAYOFWEEK(f_datetime)   
  29.     WHEN 1 THEN 7  
  30.     WHEN 2 THEN 1  
  31.     WHEN 3 THEN 2  
  32.     WHEN 4 THEN 3  
  33.     WHEN 5 THEN 4  
  34.     WHEN 6 THEN 5  
  35.     WHEN 7 THEN 6  
  36.     END;  
  37.     SET v_result = CEIL(DAYOFMONTH(DATE_SUB(f_datetime,INTERVAL v_weekno DAY))/7)+1;  
  38.     RETURN v_result;  
  39.         
  40.     END$$  
  41.   
  42.   
  43.   
  44.   
  45. DELIMITER ;  





演示下结果:


SELECT weekofmonth(NOW()) AS result;



query result:


result
4
原创粉丝点击