abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
dnes 21:21 | Nová verze Ladislav Hagara | Komentářů: 0
dnes 11:44 | Zajímavý projekt

Na Indiegogo byla spuštěna kampaň na podporu herní mini konzole a multimediálního centra RetroEngine Sigma od Doyodo. Předobjednat ji lze již od 49 dolarů. Požadovaná částka 20 000 dolarů byla překonána již 6 krát. Majitelé mini konzole si budou moci zahrát hry pro Atari VCS 2600, Sega Genesis nebo NES. Předinstalováno bude multimediální centrum Kodi.

Ladislav Hagara | Komentářů: 0
dnes 00:10 | Nová verze

Byla vydána verze 4.7 redakčního systému WordPress. Kódové označením Vaughan bylo vybráno na počest americké jazzové zpěvačky Sarah "Sassy" Vaughan. Z novinek lze zmínit například novou výchozí šablonu Twenty Seventeen, náhledy pdf souborů nebo WordPress REST API.

Ladislav Hagara | Komentářů: 0
včera 12:00 | Zajímavý projekt

Projekt Termbox umožňuje vyzkoušet si linuxové distribuce Ubuntu, Debian, Fedora, CentOS a Arch Linux ve webovém prohlížeči. Řešení je postaveno na projektu HyperContainer. Podrobnosti v často kladených dotazech (FAQ). Zdrojové kódy jsou k dispozici na GitHubu [reddit].

Ladislav Hagara | Komentářů: 24
včera 11:00 | Bezpečnostní upozornění

Byly zveřejněny informace o bezpečnostní chybě CVE-2016-8655 v Linuxu zneužitelné k lokální eskalaci práv. Chyba se dostala do linuxového jádra v srpnu 2011. V upstreamu byla opravena minulý týden [Hacker News].

Ladislav Hagara | Komentářů: 2
5.12. 22:00 | Komunita

Přibližně před měsícem bylo oznámeno, že linuxová distribuce SUSE Linux Enterprise Server (SLES) běží nově také Raspberry Pi 3 (dokumentace). Obraz verze 12 SP2 pro Raspberry Pi 3 je ke stažení zdarma. Pro registrované jsou po dobu jednoho roku zdarma také aktualizace. Dnes bylo oznámeno, že pro Raspberry Pi 3 je k dispozici také nové openSUSE Leap 42.2 (zprávička). K dispozici je hned několik obrazů.

Ladislav Hagara | Komentářů: 6
5.12. 06:00 | Zajímavý software

OMG! Ubuntu! představuje emulátor terminálu Hyper (GitHub) postavený na webových technologiích (HTML, CSS a JavaScript). V diskusi k článku je zmíněn podobný emulátor terminálu Black Screen. Hyper i Black Screen používají framework Electron, stejně jako editor Atom nebo vývojové prostředí Visual Studio Code.

Ladislav Hagara | Komentářů: 50
5.12. 06:00 | Zajímavý článek

I letos vychází řada ajťáckých adventních kalendářů. QEMU Advent Calendar 2016 přináší každý den nový obraz disku pro QEMU. Programátoři se mohou potrápit při řešení úloh z kalendáře Advent of Code 2016. Kalendáře Perl Advent Calendar 2016 a Perl 6 Advent Calendar přinášejí každý den zajímavé informace o programovacím jazyce Perl. Stranou nezůstává ani programovací jazyk Go.

Ladislav Hagara | Komentářů: 10
3.12. 16:24 | Nová verze

Byla vydána Mageia 5.1. Jedná se o první opravné vydání verze 5, jež vyšla v červnu loňského roku (zprávička). Uživatelům verze 5 nepřináší opravné vydání nic nového, samozřejmě pokud pravidelně aktualizují. Vydání obsahuje všechny aktualizace za posledního téměř půldruhého roku. Mageia 5.1 obsahuje LibreOffice 4.4.7, Linux 4.4.32, KDE4 4.14.5 nebo GNOME 3.14.3.

Ladislav Hagara | Komentářů: 17
3.12. 13:42 | Pozvánky

V Praze probíhá konference Internet a Technologie 16.2, volné pokračování jarní konference sdružení CZ.NIC. Konferenci lze sledovat online na YouTube. K dispozici je také archiv předchozích konferencí.

Ladislav Hagara | Komentářů: 0
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (24%)
 (29%)
 (8%)
 (5%)
 (3%)
Celkem 784 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama

Dotaz: SQL napric tabulkami a sloupci

2.5.2015 17:27 luksyk
SQL napric tabulkami a sloupci
Přečteno: 483×
dobry den,

mam nekolik tabulek v MySQL jejichz obsah je zhruba tento:
| ID | VALUE1 | VALUE2 | VALUE3 |
| 1  | a1     | a10    | a5     |
| 2  | a11    | a3     | a40    |
| 3  | a66    | a13    | a0     |
a ted bych rad vybral vsechny zaznamy, ktere obsahuji pismeno "a" a mel je serazene (idealne natural sort, ale netrvam na tom) a to tak, aby vysledek vypadal nejak takto:
| ID | VALUE  |
| 3  | a0     |
| 1  | a1     |
| 2  | a3     |
| 1  | a5     |
| 1  | a10    |
| 2  | a11    |
| 3  | a13    |
| 2  | a40    |
| 3  | a66    |
zatim to delam hloupe tak, ze to vyhledavam separe a pak to sortuju v PHP. zajima mne, jestli lze sestavit SQL dotaz, ktery by to sam zvladnul

dekuji.

Odpovědi

2.5.2015 17:55 jekub
Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
Ano, rika se tomu join
2.5.2015 17:57 jekub
Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
sory, beru zpet. Neprecetl sem si poradne dotaz.
2.5.2015 18:00 Kit | skóre: 36 | Brno
Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
Použij UNION ALL
Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
2.5.2015 23:42 Tomáš
Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci

select
  T.ID
  ,case E.VAL
     when 'VALUE1' then T.VALUE1
     when 'VALUE2' then T.VALUE2
     when 'VALUE3' then T.VALUE3
   end as VALUE
from T
cross join razdvatri as E
order by VALUE
tabulka razdvatri vypadá následovně:
'VAL'
----
VALUE1
VALUE2
VALUE3

Stačí si uvědomit, že jeden zdrojový řádek se roznásobí na tři cílové. Jakým trikem si tabulku razdvatri vyrobíte je na vás.

Sort je jen třešinka na dortu.

Další varinata je udělat union ze tří selectů {VALUE1,VALUE2,VALUE3}, ale to znamená sjíždět tabulku T 3× což asi nebude úplně optimální. Paradoxně join na třířádkouvou tabulku razrazdvatři, pravděpodobně vyjde z rychlostně lépe.

xkucf03 avatar 2.5.2015 23:44 xkucf03 | skóre: 45 | blog: xkucf03
Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
SELECT * FROM (
    SELECT id, value1 AS value FROM tabulka WHERE value1 LIKE '%a%'
    UNION ALL
    SELECT id, value2 AS value FROM tabulka WHERE value2 LIKE '%a%'
    UNION ALL
    SELECT id, value2 AS value FROM tabulka WHERE value2 LIKE '%a%'
) AS t ORDER BY t.value
Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-Výuka.cz, Nekuřák.net
3.5.2015 09:03 Filip Jirsák
Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
Pokud potřebujete dělat takovéhle dotazy a dávají smysl, pak to především vypadá, že máte špatně navrženou strukturu databáze. Že by ta tabulka měla vypadat takhle nějak:
| ID | TYPE  | VALUE |
| 1  | VALUE1| a1    |
| 1  | VALUE2| a10   |
| 1  | VALUE3| a5    |
| 2  | VALUE1| a11   |
| 2  | VALUE2| a3    |
| 2  | VALUE3| a40   |
| 3  | VALUE1| a66   |
| 3  | VALUE2| a13   |
| 3  | VALUE3| a0    |
Pak by i ten vámi požadovaný dotaz byl triviální.
3.5.2015 10:19 Kit | skóre: 36 | Brno
Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
EAV má zase nevýhody ve spoustě jiných typů dotazů.
Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
Josef Kufner avatar 4.5.2015 15:58 Josef Kufner | skóre: 66
Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
Z praktické zkušenosti mohu říct, že nevýhody značně převažují. Než EAV je lepší mít dynamickou strukturu databáze a nechat aplikaci si upravovat vybrané tabulky. Druhá možnost je JSON a serializace z pohledu databáze nepodstatných údajů do jednoho sloupce. Záleží na situaci.
Hello world ! Segmentation fault (core dumped)
4.5.2015 18:32 Kit | skóre: 36 | Brno
Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
Nebo použít PostgreSQL a hstore.
Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
4.5.2015 16:34 Filip Jirsák
Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
Není jisté, že jde o EAV – je možné, že to vzniklo až zjednodušením pro dotaz v poradně. Vzhledem k tomu, jaký požaduje tazatel výstup, bych spíš tipoval, že o EAV nejde (požadovaný výstup by pak nedával moc smysl).
Josef Kufner avatar 4.5.2015 15:56 Josef Kufner | skóre: 66
Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
SQL neumí pracovat s proměnlivým počtem sloupců. Viděl bych to na nešikovně navrženou databázi, ale pokud jinak dává smysl, tak řešením je UNION selectů nad jednotlivými sloupci (jak už zde bylo řečeno).
Hello world ! Segmentation fault (core dumped)

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267   www.czech-server.cz
© 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.