SQL Date Functions
SQL Dates
The most difficult part when working with dates is to be
sure that the format of the date you are trying to insert, matches the format of the
date column in the database.
As long as your data contains only the date portion, your queries will work
as expected. However, if a time portion is involved, it gets complicated.
Before talking about the complications of querying for dates, we will look at
the most important built-in functions for working with dates.
MySQL Date Functions
The following table lists the most important built-in date functions in MySQL:
Function |
Description |
NOW() |
Returns the current date and time |
CURDATE() |
Returns the current date |
CURTIME() |
Returns the current time |
DATE() |
Extracts the date part of a date or date/time expression |
EXTRACT() |
Returns a single part of a date/time |
DATE_ADD() |
Adds a specified time interval to a date |
DATE_SUB() |
Subtracts a specified time interval from a date |
DATEDIFF() |
Returns the number of days between two dates |
DATE_FORMAT() |
Displays date/time data in different formats |
SQL Server Date Functions
The following table lists the most important built-in date functions in SQL Server:
Function |
Description |
GETDATE() |
Returns the current date and time |
DATEPART() |
Returns a single part of a date/time |
DATEADD() |
Adds or subtracts a specified time interval from a date |
DATEDIFF() |
Returns the time between two dates |
CONVERT() |
Displays date/time data in different formats |
SQL Date Data Types
MySQL comes with the following data types for storing a date or a date/time
value in the database:
- DATE - format YYYY-MM-DD
- DATETIME - format: YYYY-MM-DD HH:MM:SS
- TIMESTAMP - format: YYYY-MM-DD HH:MM:SS
- YEAR - format YYYY or YY
SQL Server comes with the following data types for storing a date or a
date/time value in the database:
- DATE - format YYYY-MM-DD
- DATETIME - format: YYYY-MM-DD HH:MM:SS
- SMALLDATETIME - format: YYYY-MM-DD HH:MM:SS
- TIMESTAMP - format: a unique number
Note: The date types are chosen for a column when you create a new
table in your database!
For an overview of all data types available, go to our complete
Data Types reference.
SQL Working with Dates
You can compare two dates easily if there
is no time component involved!
Assume we have the following "Orders" table:
OrderId |
ProductName |
OrderDate |
1 |
Geitost |
2008-11-11 |
2 |
Camembert Pierrot |
2008-11-09 |
3 |
Mozzarella di Giovanni |
2008-11-11 |
4 |
Mascarpone Fabioli |
2008-10-29 |
Now we want to select the records with an OrderDate of "2008-11-11" from the
table above.
We use the following SELECT statement:
SELECT * FROM Orders WHERE OrderDate='2008-11-11'
|
The result-set will look like this:
OrderId |
ProductName |
OrderDate |
1 |
Geitost |
2008-11-11 |
3 |
Mozzarella di Giovanni |
2008-11-11 |
Now, assume that the "Orders" table looks like this (notice the
time component in the "OrderDate" column):
OrderId |
ProductName |
OrderDate |
1 |
Geitost |
2008-11-11 13:23:44 |
2 |
Camembert Pierrot |
2008-11-09 15:45:21 |
3 |
Mozzarella di Giovanni |
2008-11-11 11:12:01 |
4 |
Mascarpone Fabioli |
2008-10-29 14:56:59 |
If we use the same SELECT statement as above:
SELECT * FROM Orders WHERE OrderDate='2008-11-11'
|
we will get no result! This is because the query is looking only for dates
with no time portion.
Tip: If you want to keep your queries simple and easy to maintain, do
not allow time components in your dates!
The Altova MissionKit is a suite of intelligent XML tools, including:
XMLSpy® – industry-leading XML editor
- Support for all XML-based technologies
- Graphical editing views, powerful debuggers, code generation, & more
MapForce® – graphical data mapping tool
- Drag-and-drop data conversion with code generation
- Support for XML, DBs, EDI, Excel® 2007, text, Web services
StyleVision® – visual stylesheet designer
- Drag-and-drop stylesheet design for XML & databases
- Output to HTML, PDF, RTF, Word 2007, & more
And more…
Try before you buy with a free fully functional 30-day trial
Download today
|