mysql 日期处理成财年财季财月财周

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql 日期处理成财年财季财月财周相关的知识,希望对你有一定的参考价值。

参考技术A 财年是一个公司的上市时间决定的,所以不同的公司财年码表不同,因为我目前用的财年是从4月1号开始算的,自己就写了个mysql 的工具函数:

SELECT

-- 自然日

naturalday,

-- 财年

concat('FY', DATE_FORMAT(naturalday,'%y'),  DATE_FORMAT(naturalday,'%y')+1) as fiscalyear,

-- 财季

concat('Q', case when QUARTER(naturalday)=4 then 1 ELSE QUARTER(naturalday)-1 END

) as fiscalquarter,

-- 财月

DATE_FORMAT(naturalday,'%m') as fiscalmonth,

-- 财周

timestampdiff(WEEK,date(concat(year(naturalday),'-',elt(quarter(naturalday),1,4,7,10),'-',1)),naturalday) as fiscalweek

from tool_lenovo_day;

一下是我写的一个存储过程:

CREATE DEFINER=`root`@`%` PROCEDURE `sp_InitialFiscalYear_data`(`sDate` varchar(20),`eDate` varchar(20))

BEGIN

/*

工具函数:生成时间段内的lenovo的财年、财季、财月、财周数据

做成:白纸黑字

做成日:2020-07-16

入参:

sDate 开始自然日

eDate 结束自然日

业务逻辑:

tool_lenovo_day 财年表

有更新、没有新增财年数据

*/

INSERT INTO tool_lenovo_day SELECT

*

FROM

(

SELECT

naturalday,

concat( 'FY', DATE_FORMAT( naturalday, '%y' ), DATE_FORMAT( naturalday, '%y' )+ 1 ) AS fiscalyear,

concat( 'Q', CASE WHEN QUARTER ( naturalday )= 4 THEN 1 ELSE QUARTER ( naturalday )- 1 END ) AS fiscalquarter,

DATE_FORMAT( naturalday, '%m' ) AS fiscalmonth,

timestampdiff(

WEEK,

date(

concat( YEAR ( naturalday ), '-', elt( QUARTER ( naturalday ), 1, 4, 7, 10 ), '-', 1 )),

naturalday

)+1 AS fiscalweek

FROM

(

SELECT

date_add( date_sub(sDate,interval 1 day), INTERVAL ( cast( help_topic_id AS signed INTEGER ) + 1 ) day ) naturalday

FROM

mysql.help_topic

WHERE

help_topic_id < DATEDIFF(eDate,date_sub(sDate,interval 1 day))

ORDER BY

help_topic_id

) as s_e_day

) AS a

ON DUPLICATE KEY UPDATE fiscalyear = a.fiscalyear,

fiscalquarter = a.fiscalquarter,

fiscalmonth = a.fiscalmonth,

fiscalweek = a.fiscalweek;

END

MySql中字符串转成日期

在MySql中怎么比较两个日期的大小,我在数据库中日期使用varchar存储的,比如2013-12-26 01:13:57

参考技术A 如果月份日期是固定两位(个位数的会补0的话),直接比较就行了,因为按照字母顺序比较,数字大小也是可以正确比较的。本回答被提问者采纳 参考技术B SELECT
t1.date_1,
t2.date_2,

IF (t1.date_1 > t2.date_2, 1, 0)
FROM
(
SELECT
'2013-12-27 00:14:57' AS date_1
) t1
INNER JOIN (
SELECT
'2013-12-26 01:13:58' AS date_2
) t2 ON 1 = 1;
使用这个测试了一下,t1.date_1 > t2.date_2 这样比较日期是可以的

以上是关于mysql 日期处理成财年财季财月财周的主要内容,如果未能解决你的问题,请参考以下文章

在PHP中处理日期

云计算立功!阿里第四财季营收1143.14亿元,电商业务创历史新低

微软第四财季业绩不及预期,增速再创新低

MySQL处理函数

本地日期格式不同时处理 mySQL 日期格式

Node.js怎么处理数据库中日期类型