Avatar billede pelskee Nybegynder
07. januar 2004 - 10:42 Der er 11 kommentarer og
1 løsning

Hvilken datatype skal jeg bruge til priser

Hvilken datatype skal jeg bruge til at lagre priser (59,95) ?
Avatar billede powerade Nybegynder
07. januar 2004 - 10:43 #1
MySQL har ikke noget der understøtter "currency" derfor brug enten
Decimal eller Float
http://www.sqlconverter.com/excel/docs/mysql-datatypes.htm
Avatar billede pelskee Nybegynder
07. januar 2004 - 10:47 #2
okay - det er ændret. tak for det hurtige svar

jeg får fejl når jeg forsøger at oprette en pris med decimaler:

Microsoft OLE DB Provider for ODBC Drivers error '80040e09'

[TCX][MyODBC]You have an error in your SQL syntax near '20,Pris_DKK_v6 = 52,20,Aktiv_Dansk = 'Y',Aktiv_Svensk = 'N',Overskrift = 'Don Da' at line 1

/admin/vin/opdater_vin.asp, line 131
Avatar billede pelskee Nybegynder
07. januar 2004 - 10:50 #3
jeg kan ikke få det til at virke når jeg angiver: 59,95 på en pris får jeg fejl. angiver jeg 59.95 godtager den det, men næste gang jeg ser på den pågældende record er prisen oprundet til 60.
Avatar billede pelskee Nybegynder
07. januar 2004 - 10:51 #4
sådan står feltet til i databasen:
Pris_DKK  decimal(10,0)  Ja  NULL
Avatar billede powerade Nybegynder
07. januar 2004 - 10:51 #5
Du ska nok "kapsle" prisen ind i `52,20` eller '52,20' Ellers tror den at de komma adskiller 2 værdier.
Avatar billede fsconsult.dk Nybegynder
07. januar 2004 - 10:54 #6
benyt altid decimal til beløb (float har en unøjagtighed).

f.eks. decimal(10,2) for et decimaltal med 2 decimaler.

Hvis du gemmer det direkte med SQL skal du huske at der skal benyttes decimalpunktum istedetfor komma!  (59.95 og ikke 59,95).
Avatar billede pelskee Nybegynder
07. januar 2004 - 10:59 #7
thanks.

det virker når jeg skriver 59.95 - MEN :)
når jeg så skal ind og opdatere det samme produkt står prisen som 59,95 og så kan jeg rette prisen igen før jeg får lov til at opdatere

kan man ikke komme uden om det ?
Avatar billede fsconsult.dk Nybegynder
07. januar 2004 - 11:06 #8
sålænge du benytter rå sql til at opdatere databasen med, bliver du nok nødt til at oversætte mellem dansk og engelsk format når du henter/gemmer beløb.

hvis du viser beløbet med tusindadskillelse (5.999,95) skal du også huske at fjerne tusind-punktummer før du gemmer beløbet og erstatter decimalkomma med punktum.
Avatar billede pelskee Nybegynder
07. januar 2004 - 11:08 #9
damn - how do i do that ?
Avatar billede fsconsult.dk Nybegynder
07. januar 2004 - 11:15 #10
kan ikke huske ASP syntax, men noget ala:

efter select:
pris=replace(pris,".",",");  (lyder som det muligvis er unødvendigt, hvis du allerede får "," i prisen).

før update:
pris=replace(pris,".","");  (fjerne tusindpunktummer)
pris=replace(pris,",","."); (erstart decimalpunktum med decimalkomma).
Avatar billede pelskee Nybegynder
07. januar 2004 - 11:37 #11
ok - smider du ikke svar. så poster jeg den med konverteringen i asp afdelingen
Avatar billede fsconsult.dk Nybegynder
07. januar 2004 - 11:40 #12
svar
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