RJWEBDESIGN - tvorba webových prezentací - Blogspot - MYSQL - Zajimavá úloha v MYSQL

RJWEBDESIGN - tvorba webových prezentací

Novinky

27.06.2010
Spoluvyvíjeli jsme aplikaci pro klienta České Dráhy. Aplikace je opět striktně soukromá, nelze uvést odkaz.

16.05.2010
Pro Vodafone jsme naprogramovali aplikaci, která vyhodnocuje interní statistiky. Vývoj trval 2 měsíce. Aplikace není veřejná, proto neuvádím odkaz.

08.03.2010
Nová firemní prezentace firmy AH Electronics s.r.o, k velké spokojenosti zákazníka se připravuje internetový obchod.

30.01.2010
Připraveno nové diskusní fórum. více

02.12.2009
Po několika měsících náročné práce jsem spustil herní portál GAMEWAY.CZ více


Něco málo o mé osobě

Je mi 28 let, bydlím v hlavním městě ČR. Webdesignem a programováním se zabývám již několik let. Pracuji jako programátor ve společnosti AndWeb s.r.o. Ovládám velmi dobře XHTML, CSS, PHP, MYSQL. Středně pokročilou znalost jQuery, 2D Grafika (Adobe Photoshop, SEO optimalizace.


Oblíbené stránky


Cizí krmivo


Přispívám a nechávam si poradit


Sport, sleduji, hraji


Reklama

Španělský fotbal - spanelskyfotbal.cz
Hlavní Logo

Poslední komentáře

  • RJ -

    [369] Když nebudeš vědět něco konkrétního, klidně se zeptej, ale neptej se na celý skript :)

  • Smoula -

    .. sak to ze si to len „vyjal“… neboj zaklady mam dobre len ma zaujala tvoja 2.varianta na mojej stranke mam tiez aktualizaciu vysledkov, len trosku zlozitejsiu…

    Ale ok.. idem sa potrapit :)

  • RJ -

    [367] Je to takový nástin, jak by to mohlo fungovat, vyjal jsem to jako torzo ze svého fotbalového webu.

    Pokud máš nějaké základy v PHP tak to dáš dokupy, pokud ne, tak se PHP nejdřív trošku nauč, stejně bys později nevěděl složitejší věci i kdybych Ti s tímto pomohl.

    :-)

  • Smoula -

    [366]

    Ahoj, mne sa paci ta 2.varianta – vytiahnes z DB aktualne zapasy, zadas vysledky a potom POSTnes, len nejako mi ten script nejde rozbehat :(

  • RJ -

    [365] Ano, samozřejmě. Jednotlivé inputy ponesou název pole. Tj.

    [code]

    A poté projdeš post POLE a uložíš

    foreach ($_POST[„gol1“] …)
    [/code]

Statistika

  • Článků celkem: 15
  • Komentářů celkem: 108

Blogspot » MYSQL » Zajimavá úloha v MYSQL

Zajimavá úloha v MYSQL

Čtvrtek, 2 .Července 2009, 06:44, prečteno 448x

Jeden z mých dobrých přátel a kolegů z oboru potřeboval vyřešit zdánlivě jednoduchou úlohu. Dostal tabulku s daty, kde v jednom sloupečku bylo ID (autoincrement) a v druhém textové a číselné hodnoty ( kladná i záporná čísla). Výstupem mělo být "lidské seřazení".

Zkoušel jsem všechny možné funkce MYSQL, nic nefungovalo tak jak jsem potřeboval a kdyz jsem seřadil část tak jak jsem chtěl, druhá část byla třeba obráceně. Nakonec se mi to podařilo tímto dotazem.

SELECT id_hodnota, nazev_cz,
CASE
WHEN LEFT( nazev_cz, 1 ) = '-'
THEN 1
WHEN nazev_cz
REGEXP '^[0-9]'
OR LEFT( nazev_cz, 1 ) = '+'
THEN 2
ELSE 3
END AS own, ABS( nazev_cz ) AS _abs
FROM sablony_hodnoty_copy
ORDER BY own ASC , IF( own =1, _abs, NULL ) DESC , IF( own =2, _abs, NULL ) ASC , nazev_cz ASC
Řekl bych, že zajímavá věc na celém dotazu se skrývá v ORDER BY. Přikládám zároveň i dump tabulky, kdyby si to někdo chtěl zkusit a kdyby někdo přišel na lepší řešení, sem s ním, zajímá mě to. Tento dotaz bude fungovat jen v MYSQL 5+. Zároveň není vhodný na tabulku s větším počtem dat ( toto nebyl můj případ ) Soubor ke stažení (sablony_hodnoty_copy.zip)

Hodnocení: Počet hlasů: 9

Komentáře

Žádný komentář

Přidat komentář

Nový vzkaz

© 2005 - 2008 RJWEBDESIGN, všechna práva vyhrazena.
Nabízíme: Tvorba www stránek
Kontakt: telefony +420 777 856 657 | E-mail: admin@rjwebdesign.net
Spolupracujeme: Aria Studio, MXART Partnerské weby: Pesonline.cz, EuroFotbal.cz, SpanelskyFotbal.cz

© 2008 RJWEBDESIGN