Vianoce v ITnetwork sú tu! Dobí si teraz kredity a získaj až 80 % extra kreditov na e-learningové kurzy ZADARMO. Zisti viac.
Hľadáme nové posily do ITnetwork tímu. Pozri sa na voľné pozície a pridaj sa k najagilnejšej firme na trhu - Viac informácií.

Diskusia – 18. diel - MS-SQL - Dátové typy podrobnejšie

Späť

Upozorňujeme, že diskusie pod našimi online kurzami sú nemoderované a primárne slúžia na získavanie spätnej väzby pre budúce vylepšenie kurzov. Pre študentov našich rekvalifikačných kurzov ponúkame možnosť priameho kontaktu s lektormi a študijným referentom pre osobné konzultácie a podporu v rámci ich štúdia. Toto je exkluzívna služba, ktorá zaisťuje kvalitnú a cielenú pomoc v prípade akýchkoľvek otázok alebo projektov.

Komentáre
Avatar
Antonín Výtaha:23.7.2017 21:44

Kluci, jak mám nastrkat český text do databáze, aby se mi tam uložila normálně písmenka ě,č,ř a ne aby mi je to vypsalo bez háčků? Dělá mi to přesně to, co je popsáno zde v příkladu použití řetězce s podporou unikódu, na tom obrázku se sloupcem 1. Když to tam nastrkám přes Visual Studio, tak se to tam krásně zapíše jak má, ale v aplikaci už to potom blbne...

 
Odpovedať
23.7.2017 21:44
Avatar
Odpovedá na Antonín Výtaha
Michal Štěpánek:24.7.2017 8:53

A když tam ta data strkáš z "té" aplikace, tak je to OK?

Odpovedať
24.7.2017 8:53
Nikdy neříkej nahlas, že to nejde. Vždycky se totiž najde blbec, který to neví a udělá to...
Avatar
Odpovedá na Michal Štěpánek
Antonín Výtaha:24.7.2017 20:48

To právě není. Jakoby byl problém v odesílání přes INSERT do databáze, protože to co je v databázi nastrkané přes Visual Studio (jak je tam na to takový editor, přes Zobrazit data tabulky), tak to se vypíše hezky česky, ale z té aplikace to právě napíše místo tohoto: ěščřžýáíé toto:ešcržýáíé. Když jsem Goooglil tak všichni radili, že je to kvůli kódování, aby se změnilo na UTF-8 (při najezí myši na string ve VS to hlásí, že je v UTF-16), ale nemám sebemenší tuchu o tom, kde by se to ve VS nebo v té databázi měnilo. :-( Do této diskuze mne právě nalákal "Příklad", co je zde u těch řetězců s podporou unikódu, páč tam je přesně to, co se mi děje (jestli nejsem ovšem jediný, komu se to takhle zobrazuji i zde na webu).

Programuji jen pro rekreaci, tak nejspíš jen dělám blbě něco, co máte hoši v malíku. :-)

 
Odpovedať
24.7.2017 20:48
Avatar
Odpovedá na Antonín Výtaha
Hubert Ličman:26.8.2017 22:10

Použij NVARCHAR(XX), kde XX je nejdelší předpokládaná délka. Je to datově úspornější. Variantou je použití NVARCHAR(MAX), když si nejsi jistý délkou.

Odpovedať
26.8.2017 22:10
Neznám slovo "nejde"
Avatar
Hubert Ličman:26.8.2017 22:14

BTW: Poněkud mi tady chybí datový tym IMAGE, který M$ doporučuje právě a jen pro obrázky uložené v MS SQL DB.Je podobný VARBINARY.
Tento typ fakticky pracuje tak, že se snaží na pole bytů aplikovat interní on-line kompresi, což pomůže ušetřit nějaké to místo. Proto je výhodnější, než-li VARBINARY.
ALE POZOR! Datové typy Text, binery, Varbinary a Image se ukládají do BLOB polí, což je odlišná struktura uložení v DB. Fakticky to znamená, že taková pole nejsou běžnými způsoby prohledávatelná a podmínkovatelná, s výjimkou Where... Is NULL.

Odpovedať
26.8.2017 22:14
Neznám slovo "nejde"
Avatar
Tomáš Vrána:31.10.2018 22:55

První dva příklady mi fungují. Další příklady mi podle tohoto zadání nefungují. Vytvoří se tabulka, ale už se do ní nenahrají data. Tomu poslednímu příkladu nerozumím. Proč jsou tam 3 řádky? Používám Visual Studio Express 2012.

Odpovedať
31.10.2018 22:55
Každý svého štěstí strůjcem.
Avatar
Tomáš Vrána:31.10.2018 23:26

Jsem vocas. Už jsem si to zprovoznil. Ale pořád nechápu ten poslední příklad. Proč jsou tam 3 řádky? A proč mi to nevyplňuje 2. sloupec? Píše mi to tam jen <Binary data>

Odpovedať
31.10.2018 23:26
Každý svého štěstí strůjcem.
Avatar
Ondřej Trnka
Tvůrce
Avatar
Ondřej Trnka:2.11.2018 13:58

Poslední příklad je na ukázku, jak funguje datový typ "timestamp" a "uniqueidentifier". Příkaz CREATE TABLE vytvoří strukturu a každý příkaz INSERT vloží jeden řádek. 3x INSERT = tři řádky

 
Odpovedať
2.11.2018 13:58
Avatar
Odpovedá na Antonín Výtaha
Antonín Výtaha:14.4.2019 20:28

Takže odpovím si sám: Nakonec se to celé vyřešilo dopsáním písmenka N před odesílaná data do tabulky, např. SELECT [Obyvatel] FROM [Mapy] WHERE [Mesto] = N'Černožice' - právě bez toho N před Černožicemi se do tabulky dotazovalo na Cernožice, čili mi to nevrátilo nic. Kdyby to někoho také potrápilo, tak se na to musí takhle. A z vlastní hlavy to nemám, myšlenka přišla odtud: https://stackoverflow.com/…-server-2008 - jinak datový typ těch měst mám nvarchar. ;-)

 
Odpovedať
14.4.2019 20:28
Avatar
Jastrab
Člen
Avatar
Odpovedá na Antonín Výtaha
Jastrab:21.5.2019 16:37

Ono pri vytvoreni databazy treba spravne zadefinovat nieco ako kodovanie - "Collation". Preto diakritika priamo z SQL Studia fungovala ale z aplikacie nie. Pokial sa chces vyhnut pisania toho N. Ono to spomina aj na tom stackoverflow.
Dalsi problem okrem diakritiky byva aj s datumom a casom, kedy program odosiela jeden format a DB ma definovany druhy format (program miesto ISO formatu 'YYYY-MM-DD' odosle 'DD-MM-YYYY' aj ked je definovane opacne)

 
Odpovedať
21.5.2019 16:37
Robíme čo je v našich silách, aby bola tunajšia diskusia čo najkvalitnejšia. Preto do nej tiež môžu prispievať len registrovaní členovia. Pre zapojenie sa do diskusie sa zaloguj. Ak ešte nemáš účet, zaregistruj sa, je to zadarmo.

Zatiaľ nikto nevložil komentár - buď prvý!