Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Storing day and month (without year)

I'm having trouble with figuring out the best way to store some data in my database. I've got to store DD/MM dates in a database, but I'm not sure of the best way to store this so that it can be easily sorted and searched.

Basically a user will be able to save important dates in the format DD/MM, which they will be reminded of closer to the day.

The DATE data type doesn't seem completely appropriate as it includes year, but I can't think of another way of storing this data. It would be possible to include a specific year to the end of all occasions, but this almost doesn't seem right.

like image 508
Sasha Avatar asked Feb 14 '11 23:02

Sasha


2 Answers

I've got to store DD/MM dates in a database, but I'm not sure of the best way to store this so that it can be easily sorted and searched.

The best way to store date data, even if the year component is not required, is to use date. When you need to use it, you can remove the year, or replace it with the year being compared against (or current year).

Having it in date column facilitates sorting correctly, integrity, validation etc.

To cater for leap years, use a year like '0004' which allows '0004-02-29'. Using year 4 makes it slightly more complicated than year 0, but as an example, this turns the date '29-Feb' (year agnostic) into a date in this year for comparison with some other field

select     adddate(     subdate(cast('0004-02-29' as date),         interval 4 year),         interval year(curdate()) year)  result: 2011-02-28 
like image 194
RichardTheKiwi Avatar answered Oct 03 '22 00:10

RichardTheKiwi


Are these dates recurring? If not, how will you keep track of when one has "expired"? If the answer is "the app will manually remove the dates once they have expired", then why not simply store the DD/MM date as the next available instance of that date? For example:

01/02 becomes 2012-02-01, and 04\07 becomes 2011-07-04

The built-in date/time functions are so useful that I strongly recommend you not use varchars or tinyints.

like image 42
ClosureCowboy Avatar answered Oct 03 '22 01:10

ClosureCowboy