|  |  | 
|  |  | Archives of the TeradataForumMessage Posted: Sat, 06 Aug 2005 @ 08:36:23 GMT
 
 Hi, When you write your UDF using Numerics/Decimals you need to know where your Decimal point should be because Teradata represents DECIMALS internally as INTEGERS with an IMPLIED decimal point. Your example of 105.00000 would be inside Teradata represented as 
     10500000   or 0xA037A0
Since you declare your type as Decimal(10,5) The Largest number you could store would be 99,999.99999 and removing the decimal point the number is 9,999,999,999 which is bigger than will fit in a 32-bit integer so it requires a 64-bit integer. However Teradata doesn't support 64-bit integers so it will come into your function as a DECIMAL8 type which is really a 64-bit integer broken into 2 32-bit parts. 
     typedef struct
     {
     unsigned long int low;
     long int high;
     } DECIMAL8, NUMERIC8;
The easiest way to deal with this inside your function is to convert it back to a 64-bit integer. Here is how your Trunc function would be coded. 
     Replace FUNCTION mytrunc
     (myval DECIMAL(10,5))
     RETURNS VARCHAR(10)
     SPECIFIC mytrunc
     LANGUAGE C
     NO SQL
     DETERMINISTIC
     PARAMETER STYLE TD_GENERAL
     EXTERNAL ;
     -----------------  mytrunc.c -------------------
     #define SQL_TEXT Latin_Text
     #include "sqltypes_td.h"
     #include From the manual. 
     FOR DECIMAL(n,m) or NUMERIC(n,m), where =85 Use one of these C types =85
     1 <= n <= 2 DECIMAL1 or NUMERIC1
     3 <= n <= 4 DECIMAL2 or NUMERIC2
     5 <= n <= 9 DECIMAL4 or NUMERIC4
     10 <= n <= 18 DECIMAL8 or NUMERIC8
     C Data Type Definition
     typedef signed char DECIMAL1;
     typedef short DECIMAL2;
     typedef long int DECIMAL4;
     typedef struct
     {
     unsigned long int low;
     long int high;
     } DECIMAL8;
 | ||||||||||||||||||||||||||||||||||||||||||||||
|  | ||||||||||||||||||||||||||||||||||||||||||||||||
| 
 | ||||||||||||||||||||||||||||||||||||||||||||||||
|   | ||||||||||||||||||||||||||||||||||||||||||||||||
| Copyright 2016 - All Rights Reserved | ||||||||||||||||||||||||||||||||||||||||||||||||
| Last Modified: 15 Jun 2023 | ||||||||||||||||||||||||||||||||||||||||||||||||