Diskuze: ASP.NET WebForms string.Format pomocí smyčky a následné vložení dat do DB tabulky
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 10 zpráv z 10.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
a ještě jsem zapomněl, poté co jsou data úspěšně zapsána do tabulky,
následuje vyskakovací okno s hláškou Úspěšně
zaúčtováno docela by se mi hodilo ještě poradit, jak udělat to,
že po kliknutí na ok se využije
Response.Redirect(Request.Url.AbsoluteUri); a stránka se
refreshne
a kdyz napises
cmd.Parameters.AddWithValue("@Cástka", 120.54);
tak se ulozi do databaze co ?
ahoj ano, pokud jsem zadal hodnotu "natvrdo" tak se mi to číslo tudíž 120.54 zapsalo bez problémů. Můžeš trošku tu tvou myšlenku rozšířit? díky
string.Format neresi problem prevodu mezi stringem a floatem. ty se pokousis
stale zapsat retezec do sloupce typu string. resenim je prevest si v c# ten
string na float.
cmd.Parameters.AddWithValue("@Cástka",
Convert.ToSingle(Cástkas[i]));
nebo float.Parse, float.TryParse
díky moc, momentálně už nejsem na PC, ale hned zítra to vyzkouším a dám vědět. Jde vidět, že jsem ještě v začátcích a neuvědomil jsem si (jako už poněkolikáté), že hodnotu float do stringu prostě nenarvu
Na měnu se float vůbec nehodí. Hodnota 120.54 je typu double (zkus si deklarovat float s desetinnou čárkou -> nepůjde to, muselo by to být ve formátu 120.54f. K tomu je tam problém se zaokrouhlováním.
float x = 3.5f;
float y = 0.1f;
float z = 3.6f;
Console.WriteLine("x+y: {0}", x+y);
Console.WriteLine("z: {0}", z);
Console.WriteLine("x+y==z?: {0}", (x + y) == z); // hodí false
Spíše použij datový typ decimal.
http://www.noelherrick.com/…al-for-money
http://stackoverflow.com/…ent-currency
Zdravím,
zkoušel jsem všechny Vaše rady, ale zatím sem nedošel k úspěšnému konci. vyzkoušel jsem:
cmd.Parameters.AddWithValue("@Cástka", Convert.ToSingle(Cástkas[i]));
cmd.Parameters.AddWithValue("@Cástka", Convert.ToDouble(Cástkas[i]));
cmd.Parameters.AddWithValue("@Cástka", Convert.ToDecimal(Cástkas[i]));
to stejné sem zkoušel se všema možnýma variantama přes parse, dokonce jsem zkoušel i deklarovat desetinnou čárku pro float přes string.Format, ale vždy to zapsalo pouze celé číslo, jsem z toho jelen, protože ještě využívám LINQ pro CRUD metodu, kde mi následně úprava na desetinné místa funguje bez problémů...
Jestli vás ještě něco napadá budu vděčný díky
napis sem presne obsah promene Cástkas[i]. budto tam mas nejaky nepovoleny
symbol jako "20.55 Kč" nebo zadavas desetinou carku zatimco system/aplikace
bezi pod anglickou verzi takze nebere carku jako validni desetini oddelovac.
nebo tady
string[] Cástkas = Request.Form["Cástka"].Split(',');
pokud pouzivas desetinou carku na ceske lokalizaci tak se ti to logicky rozsekne
na cele cislo a desetinou cast kterou nejspis pak ignorujes.
tak problém je vyřešen, chyba byla, že bylo třeba změnit
string[] Cástkas = Request.Form["Cástka"].Split(',');
na
string[] Cástkas = Request.Form["Cástka"].Split('.');
neboli jak si říkal, používal sem čárku jako rozdělovač u desetinných míst a ten split to nějak rozsekával a tu čárku ignoroval, dík moc
Zobrazeno 10 zpráv z 10.