mam dosc specyficzny problem
mam tabele ktorej struktura w uproszczeniu wyglada tak:
CREATE TABLE `magazyny` ( `id` smallint(3) NOT NULL AUTO_INCREMENT, `wartosc` float(10,2), `data_aktualizacji` timestamp(10), PRIMARY KEY (`id`) ) ENGINE=MyISAM;
i probojac operacji:
INSERT 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ł)