DevProTalk

DevProTalk (http://www.devprotalk.com/index.php)
-   SQL baze podataka - Sponzor: Baze-Podataka.net (http://www.devprotalk.com/forumdisplay.php?f=10)
-   -   Upis brojcanih vrednosti sa zarezom i tackom u MySQL (http://www.devprotalk.com/showthread.php?t=7505)

martinluter 19. 05. 2009. 18:31

Upis brojcanih vrednosti sa zarezom i tackom u MySQL
 
Molim vas za pomoc!
Ne znam kako da upisujem vrednosti tipa 1.500,13 din. (hiljadupetsto dinara i 13 para) u bazu. To sam naveo kao primer, a vrednosti ce ici i u milion i nesto.
Da li trebam da postavim kolonu u koju upisujem kao float, decimal, varchar itd?

Ja sam probao sa decimal i float, ali mi ne upisuje zarez i vrednost iza zareza. Jedino kad postavim kolonu kao varchar tad upisuje sve.

Problem mi isto predstavlja kad iscitam vrednost 1.500,13 iz baze i uporedim je sa brojem 2, ispostavi se da se radi o 1 zarez 5, odnosno jedan ipo, a ne hiljadu ipo. Ispada da mi je 1.500 isto kako 1,5.
Pomozite!

bluesman 19. 05. 2009. 18:42

Ako nisi podesio da radi "po našem" onda moraš da koristiš . kao decimalni zarez.

Obavezno koristi FLOAT(x,y) naročito ako ćeš da radiš neke računske operacije, X je broj mesta, a Y je broj decimalnih mesta, na primer FLOAT(7,2) može da upiše sedmocifren broj sa 2 rezervisana mesta. Pri tom ako upisuješ broj sa 3 decimale, mysql bi trebao sam da radi zaokruživanje.

A ako ćeš da prikazuješ "po našem" onda pre ispisa koristi funkciju za formatiranje brojeva, recimo u PHP je to number_format()

martinluter 19. 05. 2009. 20:53

Gorane, hvala na odgovoru!
Nista nije podeseno i menjano, ne znma ni gde treba, tako da "." koristi kao decimalni zarez.
Ostao sam na varchar jer nece mi biti potrebno da radim neke racunske operacije na tim vrednostima. Potrebno mi je samo za odredjivanje uslova pomocu "BETWEEN".
Inace se neka vrednost upisuje u bazu u obliku 24000.45, a kad ga iscitavam formatiram ga na ovaj moj neobican nacin:
Kôd:

$c=str_replace(".",",",$vr[cena]);
$c1=strrev($c);
$c2 = wordwrap($c1, 3, ".", 1);
$cc= strrev($c2);
$cc=str_replace(".,",",",$cc);

Mozda malo neobicno, al zavrsava posao!

bluesman 19. 05. 2009. 22:21

Joj, joj, joj ... :D

Baš taj between će ti raditi duplo brže ako koristiš float. A što se tiče formatiranja, ne znam da li si mogao komplikovanije :)

Ako imas float vrednost $vr['cena'] i hoces da umesto 24000.45 ispises 24.000,45 onda koristis number_format ($vr['cena'], 2, ",", "."); i dobiješ baš to što ti treba.


Vreme je GMT +2. Trenutno vreme je 23:05.

Powered by vBulletin® Verzija 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Copyright © DevProTalk. All Rights Reserved.

Mišljenja, saveti, izjave, ponude ili druge informacije ili sadržaji nastali na Sajtu su vlasništvo onoga ko ih je kreirao, a ne DevProTalk.com, tako da ne morate da se oslanjate na njih.
Autori poruka su jedini odgovorni za ovakve sadržaje. DevProTalk.com ne garantuje tačnost, kompletnost ili upotrebnu vrednost informacija, stavova, saveta ili datih izjava. Ne postoje uslovi pod kojima bi mi bili odgovorni za štetu ili gubitak koji je posledica bilo čijeg oslanjanja na nepouzdane informacije, ili bilo kakve informacije nastale kroz komunikaciju između registrovanih članova.
Web sajt može sadržavati linkove na druge web sajtove na Internetu ili neke druge sadržaje. Ne kontrolišemo niti podržavamo te druge web sajtove, niti smo pregledali bilo kakve sadržaje na takvim sajtovima. Mi nećemo biti odgovorni za legalnost, tačnost ili prikladnost bilo kog sadržaja, oglasa, proizvoda, usluga ili informacije lociranim na ili distribuiranih kroz druge web sajtove, niti za bilo kakvu štetu nastalu kao posledica takvih informacija. DevProTalk.com drži i čuva druga prava vlasništva na web sajtu. Web sajt sadrže materijale zaštićene copyright-om, zaštitne znakove i druge informacije o pravu vlasništva ili softver. Članovi mogu poslatu informacije zaštićene pravima vlasništva njihovih nosilaca i ona ostaju zaštićena bez obzira da li su oni koji prenose te informacije to naveli ili ne. Osim informacija koje su u javnom vlasništvu ili za koje dobijete dozvolu, nemate pravo da kopirate, modifikujete ili na bilo koji način menjate, objavljujete, prenosite, distribuirate, izvršavate, prikazujete ili prodajte bilo koju informaciju zaštićenu pravima vlasništva. Slanjem informacija ili sadržaja na bilo koji deo DevProTalk.com, Vi automatski dozvoljavate i predstavljate garanciju da imate pravo da dozvolite DevProTalk.com ili članovima DevProTalk.com bespovratnu, kontinualnu, neograničenu, globalnu dozvolu da koriste, kopiraju, izvršavaju, prikazuju i distribuiraju takve informacije i sadržaje i da iz takvih sadžaja koriste bilo koji deo u bilo koje svrhe, kao i pravo i dozvolu da koriste gore navedene sadržaje. Svi zaštitni znakovi (trademarks), logotipi, oznake usluga, firme ili imena proizvoda koji se pominju na ovom web sajtu su vlasništvo kojim raspolažu njihovi vlasnici.