Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> typ kolumny FLOAT(10,2) i wartosc 144751.40, po wpisaniu tej wartosci w bazie inna
nocnyMark()
post
Post #1





Grupa: Zarejestrowani
Postów: 50
Pomógł: 0
Dołączył: 26.04.2004

Ostrzeżenie: (0%)
-----


czesc

mam dosc specyficzny problem

mam tabele ktorej struktura w uproszczeniu wyglada tak:

  1. CREATE TABLE `magazyny` (
  2. `id` smallint(3) NOT NULL AUTO_INCREMENT,
  3. `wartosc` float(10,2),
  4. `data_aktualizacji` timestamp(10),
  5. PRIMARY KEY (`id`)
  6. ) ENGINE=MyISAM;


i probojac operacji:

  1. INSERT
  2. INTO `magazyny` VALUES (NULL,'144751.4', NULL)


w bazie zapisuje sie w pozycji WARTOSC cyfra 144751.41

czyli o 0.01 wieksza niz ja przekazalem

odkrylem ze jest to regula dla kazdej cyfry gdzie wartosc tej liczby jest wieksza niz 131074

sprawdzilem ze rzecz powtarza sie na roznych programach, sprawdzilem php i MySQLCC

sprawdzilem na mysql 4.0.20 i 4.1.13a, php 4.4.1 i 4.4.0

i wiem juz tez ze jezeli zmienie typ tego pola na DOUBLE(10,2) to ten problem minie

jednak za pelne rozwiazanie problemu uwazam znalezienie przyczyny jego

skad bierze sie cos takiego ?

czy w takim razie wartosci kwot nie przechowywac we FLOAT tylko w DOUBLE ?
i jaka jest granica dla DOUBLE ? (obracam w programie kwotami najwyzej 100 mln zł)
Go to the top of the page
+Quote Post
crash
post
Post #2





Grupa: Przyjaciele php.pl
Postów: 2 196
Pomógł: 2
Dołączył: 17.01.2004
Skąd: Sosnowiec

Ostrzeżenie: (0%)
-----


Bardzo dziwne, bo u mnie dodaje to co ma dodawać... Próbowałem i z apostrofami i bez. Działa... A zakresy typów danych znajdziesz w manualu MySQL...


--------------------
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 21.08.2025 - 17:03