This article contains a quick reference of the system-supplied data types available in SQL Server 2017, along with some basic information such as maximum length in bytes, precision, scale, and whether the data type is nullable or not (1
means it’s nullable, 0
means it’s not nullable).
Tag: mssql
How to Return a List of Data Types in SQL Server (T-SQL)
If you ever need to get a list of data types in SQL Server, you can use one of the system views to do just that.
In particular, you can use the sys.types
system catalog view. This view returns all system-supplied and user-defined data types defined in the database. If you’re using SQL Server 2000 sys.systypes
should do the trick.
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.
How to Get a List of All Languages in SQL Server (T-SQL)
Here are a couple of ways to return information on all languages in SQL Server. One method uses a system compatibility view, the other method executes a system stored procedure. Both methods return the same result.
How to Format Negative Values with Brackets in SQL Server (T-SQL)
Here’s a quick way to add brackets around negative numbers in SQL Server when using the FORMAT()
function.
The goal here is that brackets are only added to negative values. No brackets are added to positive values or zeros. Also, the brackets replace any minus sign that would otherwise be displayed (in other words, no minus sign is displayed when the brackets are used).
Although formatting is often best left to the presentation layer, there may be cases that dictate a T-SQL solution in SQL Server. In such cases, hopefully this article helps.
Standard Numeric Format Strings Supported by FORMAT() in SQL Server
This article provides a reference for the standard numeric format specifiers that can be used when formatting numbers using the FORMAT()
function in SQL Server. Examples included.
Some of the examples use precision specifiers (these consist of one or two digits appended to the format specifier). Precision specifiers can be a value from 0 to 99, which specifies the precision of the result. How it works depends on the format specifier being used. For some format specifiers, it will specify the total number of digits in the result, for others it will specify the number of decimal places. In other cases it will be ignored altogether.
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.
How to Apply Conditional Formatting to a Number in SQL Server using FORMAT()
Perhaps one of the lesser-known features of the FORMAT()
function in SQL Server is one that enables you to apply conditional formatting to a number.
It’s more of a .NET feature than it is a SQL Server (or T-SQL) feature, but SQL Server/T-SQL supports it all the same, allowing you to take full advantage of the ability to apply conditional formatting to numbers.
It all comes down to the format string you pass to the FORMAT()
function.
You can pass a format string that specifies how the number should be formatted, depending on whether it’s positive, negative, or zero.
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.