Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [mysql] Działania na wartościach rzeczywistych, dokładnie to dodawanie
Smoker
post 11.02.2009, 16:05:47
Post #1





Grupa: Zarejestrowani
Postów: 101
Pomógł: 5
Dołączył: 15.10.2008
Skąd: Wrocław

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


no to mam w bazie danych kolumny typu DECIMAL ktore przechowują liczby rzeczywiste do 4 miejsc po przecinku a mój problem polega na tym, że wartości po przecinku(kropce) nie są wogóle interpretowane podczas dodawania np:

  1. <?php
  2. $wartosc1 = 0.0000;
  3. $wartosc2 = 0.0003;
  4. $razem = $wartosc1 + $wartosc2;
  5. mysql_query("UPDATE liczby SET rzeczywiste='$razem' ");
  6. ?>


Myślałem, że do baza danych zapamieta teraz liczbe 0.0003 a dalej jest 0.0000 :/ Dlaczego tak sie dzieje ? Wie ktos ?


--------------------
http://streetonline.pl/?gback=1 - Kliknij i daj się podwieźć
Go to the top of the page
+Quote Post
grzehotnik
post 11.02.2009, 17:15:39
Post #2





Grupa: Zarejestrowani
Postów: 76
Pomógł: 0
Dołączył: 8.01.2009

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


Tobie chyba chodzi o liczby zmiennoprzecinkowe (double, float) w mysql określ typ danych przechowywanych w danej kolumnie jako float np.(float(3,4)) co oznacza, że możesz zapisywać liczę w formanie trzy liczby przed przecinkiem i cztery po (124,4578).
Go to the top of the page
+Quote Post
Smoker
post 11.02.2009, 21:25:04
Post #3





Grupa: Zarejestrowani
Postów: 101
Pomógł: 5
Dołączył: 15.10.2008
Skąd: Wrocław

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


no tak ale z tego co czytałem o DECIMAL to przechowuje on wartości rzeczywiste więc skąd tu ten problem ?

A co do tego FLOAT to tak jak w DOUBLE i DECIMAL najpierw jest podawana ilosc cyfr a pozniej cyfry za przecinkiem czyli dla 0.0000 byloby FLOAT(5,4) chyba ze ja mam jakas dziwna wersje phpMyAdma bo jak chcialem zrobic tak jak napisales to mi error wyskoczył:

Kod
     MySQL zwrócił komunikat:
   #1427 - For float(M,D), double(M,D) or decimal(M,D), M must be >= D (column 'nazwa_kolumny').


------------------------

Na FLOAT dalej to samo :/ jak sa 2 miejsca po przecinku to je dodaje tak jak powinien a jak mam 4 to juz sie gubi ohmy.gif kto pomoze ? Tylko nie pisac zebym zmienil na 2 miejsca po przecinku bo chce 4 :]

Ten post edytował Smoker 12.02.2009, 11:31:36


--------------------
http://streetonline.pl/?gback=1 - Kliknij i daj się podwieźć
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 Wersja Lo-Fi Aktualny czas: 28.06.2025 - 04:02