SQLite PRINTF() Function
The SQLite PRINTF() function works like the printf() function from the standard C library. The first argument is a format string that specifies how to construct the output string using values taken from subsequent arguments. If the format argument is missing or NULL then the result is NULL. The %n format is silently ignored and does not consume an argument. The %p format is an alias for %X. The %z format is interchangeable with %s. If there are too few arguments in the argument list, missing arguments are assumed to have a NULL value, which is translated into 0 or 0.0 for numeric formats or an empty string for %s.
Syntax
PRINTF(format, ...)
Parameters
format |
Specify the format string. |
... (additional arguments) |
Depending on the format string, a sequence of additional arguments should be passed in the function, each containing a value to replace a format specifiers in the format string. If there are too few arguments in the argument list, missing arguments are assumed to have a NULL value, which is translated into 0 or 0.0 for numeric formats or an empty string for %s. Additional arguments will be ignored by this function. |
Return Value
Returns the formatted string.
Example 1: printf() example
The example below shows the usage of PRINTF() function.
SELECT PRINTF("Decimals: %d %i", 200, 300); Result: Decimals: 200 300 SELECT PRINTF("More Decimals: %ld %li", 20000, 30000); Result: More Decimals: 20000 30000 SELECT PRINTF("Octals: %o %#o", 100, 100); Result: Octals: 144 0144 SELECT PRINTF("Hexadecimals: %x %#x %X %#X", 100, 100, 100, 100); Result: Hexadecimals: 64 0x64 64 0X64 SELECT PRINTF("Strings: %s", "Hello"); Result: Strings: Hello SELECT PRINTF("Scientific notation: %e %E", 123.45, 123.45); Result: Scientific notation: 1.234500e+02 1.234500E+02 SELECT PRINTF("Floats: %2.0f %2.2f %2.4f", 3.1416, 3.1416, 3.1416); Result: Floats: 3 3.14 3.1416 SELECT PRINTF("Positive signed number = %+.2f", 3.1416); Result: Positive signed number = +3.14 SELECT PRINTF("Padded number = %05d", 89); Result: Padded number = 00089 SELECT PRINTF("Number with Width = %*d", 5, 89); Result: Number with Width = 89
Example 2: Format date string
Consider a database table called BirthDay with the following records:
Name | Day | Month | Year |
---|---|---|---|
John | 2 | 5 | 2001 |
Marry | 7 | 8 | 2003 |
Kim | 3 | 10 | 1995 |
Jo | 25 | 3 | 1985 |
Suresh | 15 | 11 | 1998 |
Ramesh | 27 | 8 | 2000 |
The statement given below can be used to get the full date using values of Day, Month and Year columns.
SELECT *, PRINTF("%04d-%02d-%02d", Year, Month, Day) AS FullDate FROM Birthday;
This will produce the result as shown below:
Name | Day | Month | Year | FullDate |
---|---|---|---|---|
John | 2 | 5 | 2001 | 2001-05-02 |
Marry | 7 | 8 | 2003 | 2003-08-07 |
Kim | 3 | 10 | 1995 | 1995-10-03 |
Jo | 25 | 3 | 1985 | 1985-03-25 |
Suresh | 15 | 11 | 1998 | 1998-11-15 |
Ramesh | 27 | 8 | 2000 | 2000-08-27 |
❮ SQLite Functions