6

I have 2 fields I'm working with that are stored as smallint military structured times.
Edit I'm running on IBM Informix Dynamic Server Version 10.00.FC9

beg_tm and end_tm

Sample values

beg_tm   545
end_tm   815

beg_tm   1245
end_tm   1330

Sample output

beg_tm   5:45 am
end_tm   8:15 am

beg_tm   12:45 pm
end_tm   1:30 pm

I had this working in Perl, but I'm looking for a way to do it with SQL and case statements.

Is this even possible?


EDIT

Essentially, this formatting has to be used in an ACE report. I couldn't find a way to format it within the output section using simple blocks of

if(beg_tm>=1300) then
beg_tm = vbeg_tm - 1200

Where vbeg_tm is a declared char(4) variable


EDIT This works for hours >=1300 (EXCEPT FOR 2230 !!)
select substr((beg_tm-1200),0,1)||":"||substr((beg_tm-1200),2,2) from mtg_rec where beg_tm>=1300;

This works for hours < 1200 (sometimes.... 10:40 is failing)

select substr((mtg_rec.beg_tm),0,(length(cast(beg_tm as varchar(4)))-2))||":"||(substr((mtg_rec.beg_tm),2,2))||" am" beg_tm from mtg_rec where mtg_no = 1;


EDIT
Variation of casting syntax used in Jonathan Leffler's expression approach
SELECT  beg_tm,
        cast((MOD(beg_tm/100 + 11, 12) + 1) as VARCHAR(2)) || ':' ||
        SUBSTRING(cast((MOD(beg_tm, 100) + 100) as CHAR(3)) FROM 2) ||
        SUBSTRING(' am pm' FROM (MOD(cast((beg_tm/1200) as INT), 2) * 3) + 1 FOR 3),
        end_tm,
        cast((MOD(end_tm/100 + 11, 12) + 1) as VARCHAR(2)) || ':' ||
        SUBSTRING(cast((MOD(end_tm, 100) + 100) as CHAR(3)) FROM 2) ||
        SUBSTRING(' am pm' FROM (MOD(cast((end_tm/1200) as INT), 2) * 3) + 1 FOR 3)
      FROM mtg_rec
      where mtg_no = 39;
CheeseConQueso
  • 5,831
  • 29
  • 93
  • 126
  • 13
    HA !! I beg to differ - the 24-hour clock is the "regular" time - for the whole world basically, except the US (and Canada and Australia). – marc_s Oct 15 '09 at 15:07
  • Eek, s?he even wants insane time formats from that. Completely overlooked that. I assumed that it was just a matter of inserting a colon. – Joey Oct 15 '09 at 15:09
  • yeah that is funny and ignorant of me at the same time..... -1 for USA's measurement conventions – CheeseConQueso Oct 15 '09 at 15:09
  • 1
    Yeah, I've never heard of that as military time. Thought that was just normal time... – Rich Bradshaw Oct 16 '09 at 06:51
  • Hey, we do use 24h format in Canada. Well at least in french Canada. – Pierre-Alain Vigeant Oct 17 '09 at 17:53
  • @CheeseConQueso: I remain firm on my answer, since you said this needed to be done within an ace report. so why put th eengine through girations of select statements when ace has the time constant or you can select datetime columns and format the output by moving the datetime value into a char variable and format it with subscripting, as in my answer example. – Joe R. Nov 06 '10 at 02:24

7 Answers7

8

Please note that there is useful information at SO 440061 about converting between 12 hour and 24 hour notations for time (the opposite of this conversion); it isn't trivial, because 12:45 am comes half an hour before 1:15 am.

Next, please note that Informix (IDS — Informix Dynamic Server) version 7.31 finally reached its end of service on 2009-09-30; it is no longer a supported product.

You should be more precise with your version number; there are considerable differences between 7.30.UC1 and 7.31.UD8, for instance.

However, you should be able to use the TO_CHAR() function to format times as you need. Although this reference is to the IDS 12.10 Information Center, I believe that you will be able to use it in 7.31 (not necessarily in 7.30, but you should not have been using that for most of the last decade).

There is a '%R' format specifier for 24-hour time, it says. It also refers you to 'GL_DATETIME', where it says '%I' gives you the 12-hour time and '%p' gives you the am/pm indicator. I also found a 7.31.UD8 instance of IDS to validate this:

select to_char(datetime(2009-01-01 16:15:14) year to second, '%I:%M %p')
    from dual;

04:15 PM

select to_char(datetime(2009-01-01 16:15:14) year to second, '%1.1I:%M %p')
    from dual;

4:15 PM

I see from re-reading the question that you actually have SMALLINT values in the range 0000..2359 and need to get those converted. Often, I'd point out that Informix has a type for storing such values - DATETIME HOUR TO MINUTE - but I concede it occupies 3 bytes on disk instead of just 2, so it isn't as compact as a SMALLINT notation.

Steve Kass showed the SQL Server notation:

select
  cast((@milTime/100+11)%12+1 as varchar(2))
 +':'
 +substring(cast((@milTime%100+100) as char(3)),2,2)
 +' '
 +substring('ap',@milTime/1200%2+1,1)
 +'m';

The trick for getting the hour correct is neat - thanks Steve!

Translated into Informix for IDS 11.50, assuming that the table is:

CREATE TEMP TABLE times(begin_tm SMALLINT NOT NULL);

SELECT  begin_tm,
        (MOD(begin_tm/100 + 11, 12) + 1)::VARCHAR(2) || ':' ||
        SUBSTRING((MOD(begin_tm, 100) + 100)::CHAR(3) FROM 2) || ' ' ||
        SUBSTRING("ampm" FROM (MOD((begin_tm/1200)::INT, 2) * 2) + 1 FOR 2)
      FROM times
      ORDER BY begin_tm;

The SUBSTRING notation using FROM and FOR is standard SQL notation - weird, but so.

Example results:

     0    12:00 am 
     1    12:01 am 
    59    12:59 am 
   100    1:00 am  
   559    5:59 am  
   600    6:00 am  
   601    6:01 am  
   959    9:59 am  
  1000    10:00 am 
  1159    11:59 am 
  1200    12:00 pm 
  1201    12:01 pm 
  1259    12:59 pm 
  1300    1:00 pm  
  2159    9:59 pm  
  2200    10:00 pm 
  2359    11:59 pm 
  2400    12:00 am 

Caution: the values 559-601 are in the list because I ran into a problem with rounding instead of truncation in the absence of the cast to integer.

Now, this was tested on IDS 11.50; IDS 7.3x won't have the cast notation. However, that isn't a problem; the next comment was going to deal with that...

As an exercise in how to write the expression in SQL without conditionals, etc, this is interesting, but if anyone wrote that more than once in an entire suite, I'd shoot them for lack of modularization. Clearly, this requires a stored procedure - and a stored procedure doesn't need the (explicit) casts or some of the other trickery, though the assignments enforce implicit casts:

CREATE PROCEDURE ampm_time(tm SMALLINT) RETURNING CHAR(8);
    DEFINE hh SMALLINT;
    DEFINE mm SMALLINT;
    DEFINE am SMALLINT;
    DEFINE m3 CHAR(3);
    DEFINE a3 CHAR(3);
    LET hh = MOD(tm / 100 + 11, 12) + 1;
    LET mm = MOD(tm, 100) + 100;
    LET am = MOD(tm / 1200, 2);
    LET m3 = mm;
    IF am = 0
    THEN LET a3 = ' am';
    ELSE LET a3 = ' pm';
    END IF;
    RETURN (hh || ':' || m3[2,3] || a3);
END PROCEDURE;

The Informix '[2,3]' notation is a primitive form of sub-string operator; primitive because (for reasons that still elude me) the subscripts must be literal integers (not variables, not expressions). It happens to work usefully here; in general, it is frustrating.

This stored procedure should work on any version of Informix (OnLine 5.x, SE 7.x, IDS 7.x or 9.x, 10.00, 11.x, 12.x) that you can lay hands on.

To illustrate the equivalence of (a minor variant on) the expression and the stored procedure:

SELECT  begin_tm,
        (MOD(begin_tm/100 + 11, 12) + 1)::VARCHAR(2) || ':' ||
        SUBSTRING((MOD(begin_tm, 100) + 100)::CHAR(3) FROM 2) ||
        SUBSTRING(' am pm' FROM (MOD((begin_tm/1200)::INT, 2) * 3) + 1 FOR 3),
        ampm_time(begin_tm)
      FROM times
      ORDER BY begin_tm;

Which produces the result:

     0  12:00 am        12:00 am
     1  12:01 am        12:01 am
    59  12:59 am        12:59 am
   100  1:00 am         1:00 am 
   559  5:59 am         5:59 am 
   600  6:00 am         6:00 pm 
   601  6:01 am         6:01 pm 
   959  9:59 am         9:59 pm 
  1000  10:00 am        10:00 pm
  1159  11:59 am        11:59 pm
  1200  12:00 pm        12:00 pm
  1201  12:01 pm        12:01 pm
  1259  12:59 pm        12:59 pm
  1300  1:00 pm         1:00 pm 
  2159  9:59 pm         9:59 pm 
  2200  10:00 pm        10:00 pm
  2359  11:59 pm        11:59 pm
  2400  12:00 am        12:00 am

This stored procedure can now be used multiple times in a single SELECT statement inside your ACE report without further ado.


[After comments from the original poster about not working...]

IDS 7.31 doesn't handle non-integer values passed to the MOD() function. Consequently, the divisions have to be stored in an explicit integer variable - thus:

CREATE PROCEDURE ampm_time(tm SMALLINT) RETURNING CHAR(8);
    DEFINE i2 SMALLINT;
    DEFINE hh SMALLINT;
    DEFINE mm SMALLINT;
    DEFINE am SMALLINT;
    DEFINE m3 CHAR(3);
    DEFINE a3 CHAR(3);
    LET i2 = tm / 100;
    LET hh = MOD(i2 + 11, 12) + 1;
    LET mm = MOD(tm, 100) + 100;
    LET i2 = tm / 1200;
    LET am = MOD(i2, 2);
    LET m3 = mm;
    IF am = 0
    THEN LET a3 = ' am';
    ELSE LET a3 = ' pm';
    END IF;
    RETURN (hh || ':' || m3[2,3] || a3);
END PROCEDURE;

This was tested on IDS 7.31.UD8 on Solaris 10 and worked correctly. I don't understand the syntax error reported; but there is an outside chance of there being a version dependency - it is always crucial to report version numbers and platforms just in case. Notice that I'm careful to document where various things worked; that isn't an accident, nor is it just fussiness -- it is based on many years of experience.

Jonathan Leffler
  • 730,956
  • 141
  • 904
  • 1,278
  • beg_tm not begin_tm.... but your pure sql version worked... im going to try and install the stored proc just for that ACE reporting... thanks, you remain insane – CheeseConQueso Oct 19 '09 at 15:36
  • can't get that proc to work... getting a 201 sytanx error on first line @ position 56 - "(" in char(8) – CheeseConQueso Oct 19 '09 at 15:50
  • Which version of IDS 7.3x do you have. The function compiles when I copy'n'paste from the answer into 7.31.UD8 on Solaris 10; I get an error -717 when running it though, identifying MOD() as the problem. Looking into that now... – Jonathan Leffler Oct 19 '09 at 17:46
  • OK - the problem appears to be that MOD(n,m) does not like a non-integer as an argument, but the division gives a decimal value. I'll work out how to tweak that in few minutes... – Jonathan Leffler Oct 19 '09 at 17:49
  • "(MOD(begin_tm/100 + 11, 12) + 1)::VARCHAR(2)" can be substituted with "cast((MOD(beg_tm/100 + 11, 12) + 1) as VARCHAR(2))".... but I couldn't cast the INT... – CheeseConQueso Oct 20 '09 at 16:12
  • nvm.... "SUBSTRING(' am pm' FROM (MOD(cast((beg_tm/1200) as INT), 2) * 3) + 1 FOR 3)" works – CheeseConQueso Oct 20 '09 at 16:13
  • ACE reports is too lazy to take either cast syntax btw – CheeseConQueso Oct 20 '09 at 16:26
  • Yes - ACE has a retrograde view of legitimate SQL syntax. I'd forgotten that would be a problem - sorry. Did you get the stored procedure to work? It is going to be the most reliable solution. If not, please (**please**!) identify your IDS (or is it SE?) version precisely. – Jonathan Leffler Oct 20 '09 at 16:32
  • IBM Informix Dynamic Server Version 10.00.FC9 ..... I don't know when they updated this, but I was unaware.... mustve been that service end date – CheeseConQueso Oct 20 '09 at 16:39
  • this stored proc took on a life of its own..... see http://stackoverflow.com/questions/1596189/sql-cant-create-an-informix-stored-procedure – CheeseConQueso Oct 20 '09 at 17:40
  • btw... what about a macro within ACE to handle this? – CheeseConQueso Oct 20 '09 at 17:51
  • Answer provided to alternative question. ACE doesn't have macros per se. I should have recognized the problem sooner - ISQL doesn't recognize stored procedure syntax. Sorry! – Jonathan Leffler Oct 20 '09 at 18:03
  • @JL - i created this proposal on area51 that i think you should consider joining (& hopefully admin'ing if it gets accepted and grows) http://area51.stackexchange.com/proposals/31595/informix?referrer=9B11LPYabmq-V8jq85OoAQ2 – CheeseConQueso Apr 26 '11 at 18:39
  • @CheeseConQueso: Dori seems to think that creating an Informix group in Area 51 would filter people away from StackOverflow. What the Unix, Apple etc groups are doing on StackExchange, then, is a mystery to me. – Jonathan Leffler Apr 26 '11 at 22:29
  • yeah that's what I was thinking too.... and they have a "programming" stackexchange site, LaTeX site, etc.... – CheeseConQueso Apr 28 '11 at 13:24
  • i think it would be a good sub-division. Sometimes it's had to find good information about Informix on the innerweb. Google might return the search results in 0.12 seconds, but I'd much rather wait to get your opinion – CheeseConQueso Apr 28 '11 at 13:26
  • oh and BTW - were upgrading the operating system and informix this weekend, finally.... – CheeseConQueso Apr 28 '11 at 13:28
3

Here's a non-tested port of Steve Kass's solution to Informix.

Steve's solution itself is well tested under MS SQL Server. I like it better than my previous solutions because the conversion to am/pm time is exclusively done algebraically not requiring the help of any branching (with CASE statements and such).

Substitute the @milTime with column name if the numeric "military time" comes from the database. The @ variable is only there for test.

--declare @milTime int
--set @milTime = 1359
SELECT
  CAST(MOD((@milTime /100 + 11), 12) + 1 AS VARCHAR(2))
  ||':'
  ||SUBSTRING(CAST((@milTime%100 + 100) AS CHAR(3)) FROM 2 FOR 2)
  ||' '
  || SUBSTRING('ap' FROM (MOD(@milTime / 1200, 2) + 1) FOR 1)
  || 'm';

For reference here's my [fixed], CASE-based, solution for SQL Server

SELECT 
  CASE ((@milTime / 100) % 12)
      WHEN 0 THEN '12'
      ELSE CAST((@milTime % 1200) / 100 AS varchar(2))
  END 
  + ':' + RIGHT('0' + CAST((@milTime % 100) AS varchar(2)), 2)
  + CASE (@milTime / 1200) WHEN 0 THEN ' am' ELSE ' pm' END
mjv
  • 73,152
  • 14
  • 113
  • 156
3

mjv's second try still doesn't work. (For 0001 it gives 0:1 am, for example.)

Here's a T-SQL solution that should work better. It can be adapted to other dialects by using the appropriate syntax for concatenation and SUBSTRING.

It also works for the military time 2400 (12:00 am), which might be useful.

select
  cast((@milTime/100+11)%12+1 as varchar(2))
 +':'
 +substring(cast((@milTime%100+100) as char(3)),2,2)
 +' '
 +substring('ap',@milTime/1200%2+1,1)
 +'m';
Steve Kass
  • 7,144
  • 20
  • 26
  • 2
    +1 for a purely algebraic solution (no branching: didn't like "my" CASE stmts). Also your solution properly handles the leading 0 in the minute part. – mjv Oct 15 '09 at 18:10
  • I don't think informix is having fun with the modulus operator – CheeseConQueso Oct 15 '09 at 18:12
3

Ah, a fellow Jenzabar user (Jonathan, don't be too cruel about the schemas. They are literally decades old). Surprised you didn't ask this on the CX-Tech list. I'd've sent you an RCS-ready stored procedure for CX.

-sw

{
 Revision Information (Automatically maintained by 'make' - DON'T CHANGE)
 -------------------------------------------------------------------------
 $Header$
 -------------------------------------------------------------------------
}
procedure       se_get_inttime
privilege       owner
description     "Get time from an integer field and return as datetime"
inputs          param_time integer      "Integer formatted time"
returns         datetime hour to minute "Time in datetime format"
notes           "Get time from an integer field and return as datetime"

begin procedure

DEFINE tm_str VARCHAR(255);
DEFINE h INTEGER;
DEFINE m INTEGER;

IF (param_time < 0 OR param_time > 2359) THEN
RAISE EXCEPTION -746, 0, "Invalid time format. Should be: 0 - 2359";
END IF

LET tm_str = LPAD(param_time, 4, 0);

LET h = SUBSTR(tm_str, 1, 2);

IF (h < 0 OR h > 23) THEN
RAISE EXCEPTION -746, 0, "Invalid time format. Should be: 0 - 2359";
END IF

LET m = SUBSTR(tm_str, 3, 4);

IF (m < 0 OR m > 59) THEN
RAISE EXCEPTION -746, 0, "Invalid time format. Should be: 0 - 2359";
END IF

RETURN TO_DATE(h || ':' || m , '%R');

end procedure

grant
    execute to (group public)
1

Not sure about informix, here's what I would do in Oracle (some examples, but untested as I'm at home):

  1. Turn integer into a string: To_Char (milTime), e.g. 1->'1', 545 -> '545', 1215 -> '1215'
  2. Make sure we always have a four character string: Right('0000'||To_Char(milTime), 4), e.g. 1-> '0001', 545 -> '0545', 1215 -> '1215'
  3. Turn into a datetime: To_Date (Right('0000'||To_Char(milTime), 4), 'HH24:MI')
  4. Output into desired format: To_Char(To_Date(..),'HH:MI AM')e.g. 1->'00:01 AM', 545 -> '05:45 AM', 1215 -> '12:15 PM'

Oracle's To_Date and To_Char are proprietary, but I'm sure that there are standard SQL or Informix functions that achieve the same result without having to resort to "calculations".

Thorsten
  • 12,921
  • 17
  • 60
  • 79
1

CheeseWithCheese said it had to be done in an ACE report, so here's my ACE report...

Example of military hour smallint conversion to AM/PM format in ACE:

select beg_tm, end_tm ...

define
variable utime char(4) 
variable ftime char(7)
end

format

on every row

let utime = beg_tm  {cast beg_tm to char(4). do same for end_tm} 

if utime[1,2] = "00" then let ftime[1,3] = "12:"
if utime[1,2] = "01" then let ftime[1,3] = " 1:"
if utime[1,2] = "02" then let ftime[1,3] = " 2:"
if utime[1,2] = "03" then let ftime[1,3] = " 3:"
if utime[1,2] = "04" then let ftime[1,3] = " 4:"
if utime[1,2] = "05" then let ftime[1,3] = " 5:"
if utime[1,2] = "06" then let ftime[1,3] = " 6:"
if utime[1,2] = "07" then let ftime[1,3] = " 7:"
if utime[1,2] = "08" then let ftime[1,3] = " 8:"
if utime[1,2] = "09" then let ftime[1,3] = " 9:"
if utime[1,2] = "10" then let ftime[1,3] = "10:"
if utime[1,2] = "11" then let ftime[1,3] = "11:"

if utime[1,2] = "12" then let ftime[1,3] = "12:"
if utime[1,2] = "13" then let ftime[1,3] = " 1:"
if utime[1,2] = "14" then let ftime[1,3] = " 2:"
if utime[1,2] = "15" then let ftime[1,3] = " 3:"
if utime[1,2] = "16" then let ftime[1,3] = " 4:"
if utime[1,2] = "17" then let ftime[1,3] = " 5:"
if utime[1,2] = "18" then let ftime[1,3] = " 6:"
if utime[1,2] = "19" then let ftime[1,3] = " 7:"
if utime[1,2] = "20" then let ftime[1,3] = " 8:"
if utime[1,2] = "21" then let ftime[1,3] = " 9:"
if utime[1,2] = "22" then let ftime[1,3] = "10:"
if utime[1,2] = "23" then let ftime[1,3] = "11:"

let ftime[4,5] = utime[3,4]   

if utime[1,2] = "00"
or utime[1,2] = "01"
or utime[1,2] = "02"
or utime[1,2] = "03"
or utime[1,2] = "04"
or utime[1,2] = "05"
or utime[1,2] = "06"
or utime[1,2] = "07"
or utime[1,2] = "08"
or utime[1,2] = "09"
or utime[1,2] = "10"
or utime[1,2] = "11" then let ftime[6,7] = "AM"

if utime[1,2] = "12"
or utime[1,2] = "13"
or utime[1,2] = "14"
or utime[1,2] = "15"
or utime[1,2] = "16"
or utime[1,2] = "17"
or utime[1,2] = "18"
or utime[1,2] = "19"
or utime[1,2] = "20"
or utime[1,2] = "21"
or utime[1,2] = "22"
or utime[1,2] = "23" then let ftime[6,7] = "PM"

print column 1, "UNFORMATTED TIME: ", utime," = FORMATTED TIME: ", ftime 
Joe R.
  • 2,032
  • 4
  • 36
  • 72
  • yeah, but left it alone after the first resolution. never had the free time to play around with your suggestion – CheeseConQueso Mar 31 '11 at 15:32
  • 1
    frank - i'd log onto FB, but i'm at work. check out this proposal on area51 and consider joining in - if it gets accepted and grows, you would and Lefler would be great assets - http://area51.stackexchange.com/proposals/31595/informix?referrer=9B11LPYabmq-V8jq85OoAQ2 – CheeseConQueso Apr 26 '11 at 18:40
  • @Cheese: user Dori closed it on APR-26 at 4:22p, but its a great idea. maybe you can reword it better so it doesnt draw resistance from other SO informix poster's.. some users are real picky, if you've already noticed!.. oh, and I'm back in Puerto Rico! – Joe R. Apr 27 '11 at 01:24
  • yeah i submitted a proposal that didn't fully adhere to their stringent rules of what a stackexchange arena should facilitate. It was called "this reminds me of" and I thought it would be cool to post a media object and then others replied back what that media object reminded them of. Then, you know, the whole voting thing goes on for each submission. I'm working on that as a regular website myself anyway just for fun – CheeseConQueso Apr 28 '11 at 13:41
0

LONG-hand approach... but works

select  substr((mtg_rec.beg_tm-1200),0,1)||":"||substr((mtg_rec.beg_tm-1200),2,2)||" pm" beg_tm,
            substr((mtg_rec.end_tm-1200),0,1)||":"||substr((mtg_rec.end_tm-1200),2,2)||" pm" end_tm
    from    mtg_rec
    where   mtg_rec.beg_tm between 1300 and 2159
            and mtg_rec.end_tm between 1300 and 2159
    union
    select  substr((mtg_rec.beg_tm-1200),0,1)||":"||substr((mtg_rec.beg_tm-1200),2,2)||" pm" beg_tm,
            substr((mtg_rec.end_tm-1200),0,2)||":"||substr((mtg_rec.end_tm-1200),3,2)||" pm" end_tm
    from    mtg_rec
    where   mtg_rec.beg_tm between 1300 and 2159
            and mtg_rec.end_tm between 2159 and 2400
    union
    select  substr((mtg_rec.beg_tm-1200),0,2)||":"||substr((mtg_rec.beg_tm-1200),3,2)||" pm" beg_tm,
            substr((mtg_rec.end_tm-1200),0,2)||":"||substr((mtg_rec.end_tm-1200),3,2)||" pm" end_tm
            mtg_rec.days
    from    mtg_rec
    where   mtg_rec.beg_tm between 2159 and 2400
            and mtg_rec.end_tm between 2159 and 2400
    union
     select substr((mtg_rec.beg_tm),0,1)||":"||(substr((mtg_rec.beg_tm),2,2))||" am" beg_tm,
            substr((mtg_rec.end_tm),0,1)||":"||(substr((mtg_rec.end_tm),2,2))||" am" end_tm
            mtg_rec.days
    from    mtg_rec
    where   mtg_rec.beg_tm between 0 and 959
            and mtg_rec.end_tm between 0 and 959
    union
     select substr((mtg_rec.beg_tm),0,2)||":"||(substr((mtg_rec.beg_tm),3,2))||" am" beg_tm,
            substr((mtg_rec.end_tm),0,2)||":"||(substr((mtg_rec.end_tm),3,2))||" am" end_tm
            mtg_rec.days
    from    mtg_rec
    where   mtg_rec.beg_tm between 1000 and 1259
            and mtg_rec.end_tm between 1000 and 1259
    union
     select cast(beg_tm as varchar(4)),
            cast(end_tm as varchar(4))
    from    mtg_rec
    where   mtg_rec.beg_tm = 0
            and mtg_rec.end_tm = 0
    into temp time_machine with no log;
CheeseConQueso
  • 5,831
  • 29
  • 93
  • 126
  • there has to be a better way to do this with case'ing.... my result set comes out shorter than if I ignored the formatting.... wonder what the hell thats all about... – CheeseConQueso Oct 15 '09 at 20:53
  • That is ghastly - use the server to do the calculation and formatting for you, for pity's sake! That's why TO_CHAR() was added. – Jonathan Leffler Oct 17 '09 at 14:43
  • It also looks like your code won't handle times between midnight and 1 am correctly - those should appear as 12:01 am .. 12:59 am, not as 00:01 am .. 00:59 am. – Jonathan Leffler Oct 17 '09 at 14:45
  • Ghastly indeed... but I was just trying anything. I am going to check out your response now... – CheeseConQueso Oct 19 '09 at 15:21