Avatar billede rodding Juniormester
16. september 2004 - 15:45 Der er 4 kommentarer og
1 løsning

sql numerisk til tekst

Hvis man har det numerisk felt indeholdende '20040102,' hvordan kan man så lave det om til feltet '2004-01-02', så man kan beregne på datoen?
Avatar billede arne_v Ekspert
16. september 2004 - 15:53 #1
Prøv:

CAST(felt AS DATETIME)
Avatar billede rodding Juniormester
16. september 2004 - 16:06 #2
SQL0461] CAST fra DECIMAL til DATE er ikke understøtte
Avatar billede arne_v Ekspert
16. september 2004 - 16:09 #3
Hm - prøv så

CAST(CAST(felt AS VARCHAR) AS DATETIME)
Avatar billede rodding Juniormester
16. september 2004 - 16:28 #4
cast (cast (idadat as varchar(8)) as date)

Hvis jeg gør sådan, melder den ikke fejl, men viser kun et felt med en bindestreg i. Hvis jeg fjerner den yderste cast viser den datoen uden bindestreger.
Avatar billede kjulius Novice
25. december 2004 - 16:24 #5
DB2 accepterer følgende assignment

update qtemp/test set dato = cast(substr(char(dt), 1 , 4)
concat '-' concat substr(char(dt), 5, 2)
concat '-' concat substr(char(dt), 7, 2) as date)

Faktisk behøver man ikke engang at caste til date format for at DB2
accepter værdien. Følgende virker også:

update qtemp/test set dato = substr(char(dt), 1 , 4)
concat '-' concat substr(char(dt), 5, 2)
concat '-' concat substr(char(dt), 7, 2)
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Computerworld tilbyder specialiserede kurser i database-management

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester