• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Decimal mysql

Aruba Cloud VPS - 50% taniej przez 3 miesiące!
0 głosów
500 wizyt
pytanie zadane 31 marca 2020 w SQL, bazy danych przez Grzegorzko Obywatel (1,110 p.)
Wie ktoś jak zastosować decimal Bo Nie rozumiem zapisu ?

2 odpowiedzi

0 głosów
odpowiedź 31 marca 2020 przez Ehlert Ekspert (214,530 p.)
0 głosów
odpowiedź 31 marca 2020 przez bwaluk Mądrala (5,440 p.)

DECIMAL(M, D)

M - czyli maksymalna ilość cyfr w CAŁYM polu;
D - czyli ilość cyfr po przecinku/kropce (separatorze dziesiętnym) ;

M-D = tyle cyfr jest po lewej od separatora;
D = tyle cyfr jest po prawej od separatora;

!! M nie może być mniejsze niż D !!

Czyli jak dajesz DECIMAL(3,2) to znaczy, że możesz zapisać/wyświetlić maksymalnie taką wartość 9.99;

Przykład:

SELECT
CAST(123.456 AS DECIMAL(3,2)) AS 3cyfry_2poPrzecinku

Wynikiem będzie 9.99. Dlaczego? A no dlatego, że wartość, z której przeliczamy (123.456) jest większa, niż maks jaki jesteśmy w stanie wyświetlić i musi być zaokrąglona do góry. M = 3 czyli maksymalnie trzy cyfry, D = 2 czyli dwie po separatorze. Pierwsza cyfra jest przed kropką, a dwie kolejne za kropką. 

Jedziemy dalej z przykładami:

SELECT
CAST(123.456 AS DECIMAL(5,2)) AS 5cyfr_2poPrzecinku

Maksymalna wartość dla tego zapisu to 999.99. Wynik zapytania = 123.46 - dlaczego? A no dlatego, że wartość jest mniejsza niż nasz max więc nic po lewej się nie będzie zaokrąglało, ale po prawej już tak (wszystko zgodnie z zasadami matematycznymi).

 

W skrócie, jeżeli chcesz wiedzieć jak poprawnie zapisać/odczytać liczbę w sql - patrzysz na największą (lub potencjalnie największą), liczysz wszystkie cyferki, które tam występują i ile cyferek jest po separatorze. 

1234567890 to DECIMAL(10,0) 
123456789.0 to DECIMAL(10,1)
12345678.90 to DECIMAL(10,2)
..
12.345 to DECIMAL(5,3)
1.2345 to DECIMAL(5,4)
..
12.34 to DECIMAL(4,2)
1.2 to DECIMAL(2,1)

 

 

komentarz 31 marca 2020 przez Grzegorzko Obywatel (1,110 p.)
Wielkie dzięki.Super to wytłumaczyłeś.

Podobne pytania

0 głosów
1 odpowiedź 318 wizyt
+2 głosów
3 odpowiedzi 694 wizyt
0 głosów
1 odpowiedź 400 wizyt
pytanie zadane 8 maja 2023 w Assembler przez Saskus Nowicjusz (150 p.)

93,174 zapytań

142,185 odpowiedzi

321,972 komentarzy

62,503 pasjonatów

Advent of Code 2024

Top 15 użytkowników

  1. 1389p. - dia-Chann
  2. 1360p. - Łukasz Eckert
  3. 1246p. - CC PL
  4. 1139p. - Łukasz Piwowar
  5. 1118p. - Tomasz Bielak
  6. 1104p. - Michal Drewniak
  7. 1083p. - Marcin Putra
  8. 1078p. - rucin93
  9. 1071p. - rafalszastok
  10. 1054p. - Adrian Wieprzkowicz
  11. 1047p. - Piotr Aleksandrowicz
  12. 1037p. - Michał Telesz
  13. 1023p. - Mariusz Fornal
  14. 1017p. - Mikbac
  15. 1005p. - ssynowiec
Szczegóły i pełne wyniki

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj

Wprowadzenie do ITsec, tom 1 Wprowadzenie do ITsec, tom 2

Można już zamawiać dwa tomy książek o ITsec pt. "Wprowadzenie do bezpieczeństwa IT" - mamy dla Was kod: pasja (użyjcie go w koszyku), dzięki któremu uzyskamy aż 15% zniżki! Dziękujemy ekipie Sekuraka za fajny rabat dla naszej Społeczności!

...