Update Function TO_TIME
This commit is contained in:
@@ -1 +1,51 @@
|
||||
牄禗袬蒨@\蚕謨@^@
|
||||
SET PATH *LIBL ;
|
||||
|
||||
CREATE OR REPLACE FUNCTION CISTOOLS.TO_TIME (
|
||||
INNUM NUMERIC(6, 0) )
|
||||
RETURNS TIME
|
||||
LANGUAGE SQL
|
||||
SPECIFIC CISTOOLS.TO_TIME
|
||||
DETERMINISTIC
|
||||
READS SQL DATA
|
||||
CALLED ON NULL INPUT
|
||||
CONCURRENT ACCESS RESOLUTION DEFAULT
|
||||
SET OPTION ALWBLK = *ALLREAD ,
|
||||
ALWCPYDTA = *OPTIMIZE ,
|
||||
COMMIT = *NONE ,
|
||||
DBGVIEW = *SOURCE ,
|
||||
DECRESULT = (31, 31, 00) ,
|
||||
DFTRDBCOL = *NONE ,
|
||||
DYNDFTCOL = *NO ,
|
||||
DYNUSRPRF = *OWNER ,
|
||||
SRTSEQ = *HEX
|
||||
BEGIN
|
||||
DECLARE WKNUM CHAR ( 6 ) ;
|
||||
DECLARE RETURN_TIME TIME ;
|
||||
DECLARE CONTINUE HANDLER FOR SQLEXCEPTION
|
||||
BEGIN
|
||||
SET RETURN_TIME = TIME ( '01.01.01' ) ;
|
||||
END ;
|
||||
SET WKNUM = LPAD ( INNUM , 6 , '0' ) ;
|
||||
SET RETURN_TIME = CAST (
|
||||
LEFT ( WKNUM , 2 ) || '.' || SUBSTR ( WKNUM , 3 , 2 ) || '.' ||
|
||||
CASE
|
||||
WHEN RIGHT ( WKNUM , 2 ) > 59 THEN '59'
|
||||
ELSE RIGHT ( WKNUM , 2 )
|
||||
END AS TIME ) ;
|
||||
RETURN RETURN_TIME ;
|
||||
END ;
|
||||
|
||||
COMMENT ON PARAMETER SPECIFIC FUNCTION CISTOOLS.TO_TIME
|
||||
( INNUM IS 'Input Number' ) ;
|
||||
|
||||
LABEL ON SPECIFIC FUNCTION CISTOOLS.TO_TIME
|
||||
IS 'To Time' ;
|
||||
|
||||
GRANT ALTER , EXECUTE
|
||||
ON SPECIFIC FUNCTION CISTOOLS.TO_TIME
|
||||
TO AMAPICS WITH GRANT OPTION ;
|
||||
|
||||
GRANT EXECUTE
|
||||
ON SPECIFIC FUNCTION CISTOOLS.TO_TIME
|
||||
TO PUBLIC ;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user