How to convert integer, decimal, double or date to string?


This is very simple, since Firebird's built-in CAST operator does this very well:

select cast(22.5 as varchar(50)) from rdb$database;
select cast(integer_field as varchar(50)) from rdb$database;
select cast(date_field as varchar(50)) from rdb$database;
etc.

It uses default formatting: dot as decimal point, no thousand separator, dates in ISO-8601 format. Just make sure that size of VARCHAR field is large enough to hold the longest string representation of the datatype you are converting.

If you need special formatting, it's best to do it on the client side, in your application code. Short of that, you could combine string functions (SUBSTRING, CHAR_LENGTH, etc.) to extract the needed parts. There are also some UDF functions that can format the data for you. Take a look at rFunc and FreeAdHocUDF libraries for such functions.


Do you find this FAQ incorrect or incomplete? Please e-mail us what needs to be changed. To ensure quality, each change is checked by our editors (and often tested on live Firebird databases), before it enters the main FAQ database. If you desire so, the changes will be credited to your name. To learn more, visit our add content page.



All contents are copyright © 2007-2024 FirebirdFAQ.org unless otherwise stated in the text.


Links   Firebird   News   FlameRobin   Powered by FB: Home Inventory   Euchre  
Add content   About  

Categories
 Newbies
 SQL
 Installation and setup
 Backup and restore
 Performance
 Security
 Connectivity and API
 HOWTOs
 Errors and error codes
 Miscellaneous