In PostgreSQL, if you already have a month name, but you want to convert that name to the month number, you can do this with the EXTRACT()
function.
Tag: dates
Get the Month Name from a Date in PostgreSQL
If you’re familiar with PostgreSQL, you might know that you can use the EXTRACT()
and the DATE_PART()
functions to extract the month from a date. But those functions only allow you to extract the month number.
What if you need the month name?
You can get the month name from a date by using the TO_CHAR()
function. This function returns a string based on the timestamp and the template pattern you provide as arguments.
How Language Settings can Affect your FORMAT() Results in SQL Server (T-SQL Examples)
It can be easy to forget that the T-SQL FORMAT()
function provides locale-aware formatting. Locale-aware means that the locale can affect the results. In other words, the exact output you get will depend on the locale.
By default, the function uses the language of the current session to determine the locale. However, this can be overridden by passing a “culture” argument to the function. Doing this allows you to provide results for a particular locale without having to change the language of the current session.
This article contains examples of how locale can affect the results when using the FORMAT()
function in SQL Server.
Custom Numeric Format Strings Supported by FORMAT() in SQL Server
This article provides a reference for the custom numeric format specifiers that can be used when formatting numbers using the FORMAT()
function in SQL Server. Examples included.
What is a Format String in SQL Server?
In SQL Server, the FORMAT()
function enables you to format date/time and number values as a formatted string by passing in a “format string” as the second argument (the first argument is the value that’s being formatted).
Here’s an example of this function in action:
FORMAT(@date, 'dd/MM/yyyy');
In this case the format string is dd/MM/yyyy.
This particular format string specifies that the @date
value should be formatted with a two-digit day, two-digit month, and a four-digit year, in that order, and with forward slashes as the separators.
This would result in something like this:
21/05/2019
Custom Date/Time Format Strings Supported by FORMAT() in SQL Server
This article provides a reference for the custom date and time format specifiers that can be used when formatting dates and/or times using the FORMAT()
function in SQL Server, along with examples.
You can combine any of these format specifiers to produce a customized format string. See below for a code example and an explanation on how custom format strings work.
Standard Date/Time Format Strings Supported by FORMAT() in SQL Server
This article provides a list of the standard date and time format strings that can be used when formatting dates and/or times using the FORMAT()
function in SQL Server, along with examples using different cultures and data types.
These are the standard date and time format specifiers that are supported by the .NET Framework, and therefore, SQL Server. Each standard date and time format string is an alias for a custom date and time format string.
How to Specify the Invariant Culture when using FORMAT() in SQL Server
In SQL Server, you can use the FORMAT()
function to format date/time and number values as strings. In particular, the function provides “locale-aware” formatting, and the function accepts a “culture” argument, which allows you to specify a culture or language to use for the actual format. For example, you can pass en-us
to ensure the results are formatted in US English format.
The culture argument is optional, so if you don’t provide it, the output will be determined by the language of the current session.
The FORMAT()
function accepts any culture supported by the .NET Framework as an argument (you’re not limited to the languages explicitly supported by SQL Server).
One of the cultures supported by the .NET Framework is the invariant culture. The invariant culture is culture-insensitive. More specifically, this culture is associated with the English language but not with any country/region.
To specify that FORMAT()
should output the results using the invariant culture, simply use "iv"
for the culture argument (the third argument).
DATEDIFF() Returns Wrong Results in SQL Server? Read This.
If you’re getting some really weird results when using the DATEDIFF()
function in SQL Server, and you’re convinced the function contains a bug, don’t tear your hair out just yet. It’s probably not a bug.
There are scenarios where the results produced by this function can be pretty whacky. And if you don’t understand how the function actually works, the results will look completely wrong.
Hopefully this article can help clarify how the DATEDIFF()
function is designed to work, and provide some example scenarios of where your results might not be as you’d expect.
A Workaround for DATEDIFF() Ignoring SET DATEFIRST in SQL Server (T-SQL Example)
An interesting thing about the DATEDIFF()
function in SQL Server is that it ignores your SET DATEFIRST
value.
However, this is not a bug. Microsoft’s documentation for DATEDIFF()
clearly states the following:
Specifying
SET DATEFIRST
has no effect onDATEDIFF
.DATEDIFF
always uses Sunday as the first day of the week to ensure the function operates in a deterministic way.
In case you don’t know, SET DATEFIRST
sets the first day of the week for your session. It’s a number from 1 through 7 (which corresponds to Monday through Sunday).
The initial value for SET DATEFIRST
is implicitly set by the language setting (which you can set with the SET LANGUAGE
statement). The actual value will depend on the language that is set. For example the default value for the us_english
language is 7
(Sunday), whereas the default for the British
language is 1
(Monday).
However, you can use a SET DATEFIRST
statement to override this so that you can keep using the same language while using a different day for the first day of the week.
But as mentioned, the SET DATEFIRST
value has no effect on the DATEDIFF()
function. The DATEDIFF()
function always assumes that Sunday is the first day of the week regardless of your SET DATEFIRST
value.
This can cause some interesting problems when using DATEDIFF()
if you don’t know how it works.
If you find yourself in this situation, hopefully the examples on this page can help.
Continue reading