Diskuze: SQLite - problém s diakritikou
V předchozím kvízu, Online test znalostí Java, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 15 zpráv z 15.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí Java, jsme si ověřili nabyté zkušenosti z kurzu.
Sort pro Unicode není v SQLite dořešen a vývojáři ho asi řešit nebudou, protože by to zvětšilo velikost knihovny SQLite asi na čtyřnásobek. Tomu se chtějí vyhnout, chtějí, aby zůstala "lite". Neoficiálně sice patch existuje, ale na hostingu stejně nebývá.
Nejlépe asi bude, když výstupní data seřadíš až v Javě. Java řadit umí.
No problém je, že data Cursor předávám adaptéru a zobrazuju v ListView. Pokud budu data z Cursoru převádět do pole objektů tak to nebude moc šetrné k baterce zařízení. Navíc by se na mobilu pravděpodobně taková operace projevila nějakým zásekem.
Pokud počet řazených položek nepřekročí pár tisíc, tak bych to moc neřešil. Zkusil sis to už? Podle mne tam výkonový propad nebude žádný.
Kromě toho ta data určitě nebudeš převádět do pole objektů.
Další možností je implementovat vlastní české řazení do SQLite napsané v Javě. Ani by to nemuselo být moc dlouhé, de facto by mělo stačit sdělit SQLite, kterou porovnávací javovskou funkci má použít.
Můžeš si tu řadící funkci napsat na míru, projede položky a vybere jen ty, které začínají diakritickým znakem. Zařadit položku na správné místo by pak mělo být velmi rychlé a neříkej mi, že jich bude mnoho.
EDIT: Ono se to vlastně může projevit i u druhého znaku. Záleží, jak moc ti to vadí. Jinak ti nezbude nic jiného, než si SQLite opatchovat nebo to seřadit sortem.
Taky mě napadlo, že bych to setřídil, ale Cursor neumožňuje abych data v něm nějak třídil.
Nejprve jsi psal o poli, teď píšeš o kolekci.
SQLite se dá téměř libovolně rozšiřovat o další funkce. Funkce na české porovnávání bude na 3 řádky. Už jsi ji mohl mít napsanou.
Stejně nepochopím, že v dnešní době něco neumí UTFko, určitě bych tuto DB nepoužil.
SQLite umí UTF-8. Jen je ta podpora ořezaná na minimum, protože by bylo zbytečné mít 2× podporu českého řazení v jedné aplikaci.
Ve spoustě aplikací to prostě není potřebné. Řetězce napsané v UTF-8 se ukládají a selektují normálně, což se třeba o MySQL v defaultní konfiguraci říct nedá.
Na web, tedy jedno z nejprimitivnějších použití databáze, je SQLite mnohem výhodnější než MySQL.
Zkus to řadit až v Javě:
Collator c = Collator.getInstance(new Locale("cs"));
Collections.sort(list, c);
No zkusím vytvořit wrapper toho cursoru a vytvořit si tam metodu sort. Když to setřídím tak si vytvoří kolekce intů s pozicema v rámci původního cursoru. Přepisem metod pro získávání hodnot z cursoru bych pak dostával hodnoty z těch pozic v původním cursoru. Výkonnost asi nebude kdovíjaká, ale myslím, že to bude lepší než vytvářet kolekci objektů s těma prvkama. Nevidíte v návrhu řešení nějakej zásadní problém, kterej by mi unikl?
Zobrazeno 15 zpráv z 15.