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í
×
    dnes 16:11 | Zajímavý software

    BreezyBox je open-source shell a virtuální terminál pro populární jednočip ESP32. Nabízí základní unixové příkazy, sledování aktuálního pracovního adresáře (CWD), jednoduchý instalátor a spouštěč aplikací v podobě ELF binárních souborů, zabudovaný HTTP server nebo třeba ovládání WiFi - ukázka použití coby 'malého osobního počítače'. Ačkoliv je BreezyBox inspirovaný BusyBoxem, oproti němu má tento projekt několik externích závislostí, zejména na ESP-IDF SDK. BreezyBox je dostupný pod licencí MIT.

    NUKE GAZA! 🎆 | Komentářů: 0
    dnes 16:00 | Humor

    Byl představen cross-assembler xa.sh, napsaný čistě v Bourne shell skriptu. Tento nástroj umožňuje zpracovávat assemblerový kód pro Intel 8080, přičemž je možné snadno přidat podporu i pro další architektury, například 6502 a 6809. Skript využívá pouze různé běžné unixové příkazy jako jsou awk, sed nebo printf. Skript si lze stáhnout z GitHubového repozitáře projektu.

    NUKE GAZA! 🎆 | Komentářů: 0
    včera 17:22 | IT novinky

    Byla představena nová verze modelu Claude Opus 4.6 od společnosti Anthropic. Jako demonstraci možností Anthropic využil 16 agentů Claude Opus 4.6 k vytvoření kompilátoru jazyka C, napsaného v programovacím jazyce Rust. Claude pracoval téměř autonomně, projekt trval zhruba dva týdny a náklady činily přibližně 20 000 dolarů. Výsledkem je fungující kompilátor o 100 000 řádcích kódu, jehož zdrojový kód je volně dostupný na GitHubu pod licencí Creative Commons.

    NUKE GAZA! 🎆 | Komentářů: 16
    včera 16:44 | Komunita

    Kultovní britský seriál The IT Crowd (Ajťáci) oslavil dvacáté výročí svého prvního vysílání. Sitcom o dvou sociálně nemotorných pracovnících a jejich nadřízené zaujal diváky svým humorem a ikonickými hláškami. Seriál, který debutoval v roce 2006, si i po dvou dekádách udržuje silnou fanouškovskou základnu a pravidelně se objevuje v seznamech nejlepších komedií své doby. Nedávné zatčení autora seriálu Grahama Linehana za hatecrime však vyvolává otázku, jestli by tento sitcom v současné Velké Británii vůbec vznikl.

    NUKE GAZA! 🎆 | Komentářů: 5
    včera 13:33 | IT novinky

    Společnost JetBrains oznámila, že počínaje verzí 2026.1 budou IDE založená na IntelliJ ve výchozím nastavení používat Wayland.

    Ladislav Hagara | Komentářů: 4
    včera 11:22 | IT novinky

    Společnost SpaceX amerického miliardáře Elona Muska podala žádost o vypuštění jednoho milionu satelitů na oběžnou dráhu kolem Země, odkud by pomohly zajistit provoz umělé inteligence (AI) a zároveň šetřily pozemské zdroje. Zatím se ale neví, kdy by se tak mělo stát. V žádosti Federální komisi pro spoje (FCC) se píše, že orbitální datová centra jsou nejúspornějším a energeticky nejúčinnějším způsobem, jak uspokojit rostoucí poptávku po

    … více »
    Ladislav Hagara | Komentářů: 23
    včera 11:11 | Nová verze

    Byla vydána nová verze 2.53.0 distribuovaného systému správy verzí Git. Přispělo 70 vývojářů, z toho 21 nových. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 04:22 | Komunita

    Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 216. sraz, který proběhne v pátek 20. února od 18:00 v Red Hat Labu (místnost Q304) na Fakultě informačních technologií VUT v Brně na ulici Božetěchova 1/2. Tématem srazu bude komunitní komunikační síť MeshCore. Jindřich Skácel představí, co je to MeshCore, předvede nejrůznější klientské zařízení a ukáže, jak v praxi vypadá nasazení vlastního repeateru.

    Ladislav Hagara | Komentářů: 0
    včera 03:33 | Nová verze

    Byla vydána nová major verze 9.0 multiplatformní digitální pracovní stanice pro práci s audiem (DAW) Ardour. Přehled novinek, vylepšení a oprav v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    5.2. 13:55 | IT novinky

    Hodnota Bitcoinu, decentralizované kryptoměny klesla pod 70 000 dolarů (1,44 milionu korun).

    Ladislav Hagara | Komentářů: 14
    Které desktopové prostředí na Linuxu používáte?
     (19%)
     (6%)
     (0%)
     (10%)
     (26%)
     (3%)
     (5%)
     (2%)
     (12%)
     (29%)
    Celkem 792 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Dotaz: Filtrování záznamů v tabulce dle data

    26.1.2011 12:22 Martin Šramka
    Filtrování záznamů v tabulce dle data
    Přečteno: 370×
    Ahoj zdravím všechny.

    Potřeboval bych poradit s jedním SQL dotazem, pracuji v nemocnici a zkouším teď vytáhnout data z databáze pacientů.

    Databáze je složena z několika tabulek, z nichž každá obsahuje protokol pacitenta (řádek tabulky). Uvedu jen ty ktere potrebuju pro muj dotaz. cislo_pacienta je propojeni mezi jednotlivymi tabulkami aby bylo jasne ktere data pasuji ke kterym. Záznam se stejnym cislem pacienta muze byt v databazi nekolikrat, avsak bude se lisit v datu "protokolu" (řádku)

    SP10 - sloupce: cislo_pacienta, SP10datum_protokolu, prijmeni, jmeno, rodne_cislo //zakladni udaje o pacientovi

    SP68 - sloupce: cislo_pacienta, SP68datum_protokolu, velikost_implcocky, spoc_parametr, jmeno_cocky //protokol ktery se vypluje pri urcitem druhu operace (katarakta)

    SP45 - sloupce: cislo_pacienta, SP45datum_protokolu, sfera, cylindr, osa //vyplnuje se vzdy soucasne s SP68, ale muze byt vyplnen take samostane u pooperacnich vysetreni

    Z takovéhoto schématu bych potřeboval vygenerovat tabulku ktera bude mit tyto sloupce:

    prijmeni, jmeno, rodne_cislo, velikost_ipmlcocky, 'Datum operace katarakta' (tzn SP68datumprotokolu), sfera (datum rovno datu operace), cylindr (datum rovno datu operace), osa (datum rovno datu operace), sfera (datum mezi +3 a +12 dny od operace katarakta, vysetreni po cca 1 tydnu), cylindr (datum mezi +3 a +12 dny od operace katarakta, vysetreni po cca 1 tydnu), osa (datum mezi +3 a +12 dny od operace katarakta, vysetreni po cca 1 tydnu)

    Slovy mi jde o to abych z databaze vytahl informace o vysetreni pacienta v den operace, potom po týdnu (pacienti nechodí přesně po týdnu ale v intervalu +3 až +12 dní od operace), měsíci atd..

    Dokážu vytáhnout všechny potřebné údaje v den operace, ale nevím jak k tomu přilepit ještě info o vyšetření po týdnu, měsíci, 3měsících atd.

    Dokázal by mi někdo poradit?

    Děkuji všem za jakékoliv rady a přeji hezký den. Zdraví Martin Šramka

    Odpovědi

    26.1.2011 14:43 kuka
    Rozbalit Rozbalit vše Re: Filtrování záznamů v tabulce dle data
    Napriklad vnorenym dotazem nebo outer joinem. Ne zcela jsem pochopil co je cilem a v cem spociva problem. Join SP10 a SP68 je asi jasny a pak bych se dotazal do SP45 tolikrat, kolikrat je potreba, asi outer joinem.
    26.1.2011 15:26 Martin Šramka
    Rozbalit Rozbalit vše Re: Filtrování záznamů v tabulce dle data
    Diky za odpoved. Cilem je dostat z databaze takovouto tabulku:

    prijmeni (z SP10), jmeno (z SP10), cocka (z SP68, filtrovane podle typu cocky), atribut (z SP45 pro datum stejne, jako datum operace), atribut (z SP45 pro vetsi datum)

    Potreboval bych alespon priklad dotazu, dekuji moc:)
    26.1.2011 18:17 Martin Šramka
    Rozbalit Rozbalit vše Re: Filtrování záznamů v tabulce dle data

    Moc děkuji za odpověd. V prvním příspěvku jsem se to snažil trošku zestručnit... Dotaz, který používám já pro vytažení potřebných informací v den operace přikládám (je dost mozne ze je v nem chyba, ale data generuje pri kontrole spravne), je tam vložena i část, kterou nevím jak udělat. Mohl bych Vás požádat o modifikaci tohoto dotazu tak aby fungoval i pro vysetreni po tydnu a mesici?

    Mnohokrate dííík. M.

     

    SELECT SP68CIS AS 'Číslo pacienta',

    SP10PRI AS 'Příjmení',

    SP10JME AS 'Jméno',

    SP10ROC AS 'Rodné číslo',

    SP10POH AS 'Pohlaví - 0:Neuvedeno, 1:Muž, 2:Žena',

    SP68DAT AS 'Surgery date',

    SP68TDA2 AS 'Calcul. IOL',

    SP68DHOD AS 'Implant. IOL',

    SP45DNAD AS 'UV',

    SP45DVID AS 'Distance BV',

    SP45DSFD AS 'SF',

    SP45DCYD AS 'CYL',

    SP45DAXD AS 'axis',

    SP35NTD AS 'IOP',

    SP35CCD AS 'CCT',

    --a tohle uz nevim jak dal udelat

    SP45DNAD AS 'UV', -- po tydnu

    SP45DVID AS 'Distance BV', -- po tydnu

    SP45DSFD AS 'SF', -- po tydnu

    SP45DCYD AS 'CYL', -- po tydnu

    SP45DAXD AS 'axis', -- po tydnu

    SP35NTD AS 'IOP', -- po tydnu

    SP35CCD AS 'CCT',-- po tydnu

    SP45DNAD AS 'UV', -- po mesici

    SP45DVID AS 'Distance BV', -- po mesici

    SP45DSFD AS 'SF', -- po mesici

    SP45DCYD AS 'CYL', -- po mesici

    SP45DAXD AS 'axis', -- po mesici

    SP35NTD AS 'IOP', -- po mesici

    SP35CCD AS 'CCT', -- po mesici

    SP68IMOD AS 'Typ čočky',

    SP60ODG, SP35CCD

    FROM SP10, SP45, SP35, SP60, SP68

    WHERE SP68.SP68CIS=SP10.SP10CIS AND SP68.SP68CIS=SP60.SP60CIS

    AND (SP68.SP68CIS=SP45.SP45CIS AND SP68DAT=SP45DAT)

    AND (SP68.SP68CIS=SP35.SP35CIS AND SP68DAT=SP35DAT)

    AND(UCASE(SP60ODG) LIKE UCASE('%tara%od%')) -- filtruji zde, ze se jedna o operaci katarakta

    AND UCASE(SP68IMOD) LIKE UCASE('%PDIFF%') -- filtr, ze se pacientu implantuje cocka pdiff

    26.1.2011 22:59 kuka
    Rozbalit Rozbalit vše Re: Filtrování záznamů v tabulce dle data
    Tabulky SP35 a SP45 se pripoji jeste jednou (tzn. tabulkam je treba priradit aliasy) pomoci left join, coz znamena, ze ke spojeni dojde pouze pokud zaznam splnujici podminky existuje, jinak jsou "hodnoty" z takto pripojene tabulky null (no proste najdi si na wikipedii co je outer join, tam to bude vysvetlene lepe), coz v tomto pripade znamena, ze pacient na kontrole nebyl. Podminka bude "datum between operace.datum + 4 and operace.datum + 12" treba. Podobne pro mesic, ale tam bude podminka jina. Konkretni syntaxi si vyhledej pro svou databazi. Doporucuju zalozit si dve tabulky o trech sloupcich a na nich si to vyzkouset, toto mi pripada matouci, zcela se ztracim v tech podivnych kodech.
    27.1.2011 11:25 Martin Šramka
    Rozbalit Rozbalit vše Re: Filtrování záznamů v tabulce dle data
    Děkuji za radu vyzkousim. M.
    27.1.2011 12:09 Martin Šramka
    Rozbalit Rozbalit vše Re: Filtrování záznamů v tabulce dle data

    Tak posílám řešení mého problému, viz dotaz. Funguje to.
    Problém je však v tom, že generování dotazu zabere cca 1 hodinu, a to jsem tam měl vyšetření pouze po týdnu, je možné, že když tam přidám po měsíci tak bude trvat ještě mnohem déle. Nenapadlo by Vás jakým způsobem to zooptimalizovat (je-li to vůbec možné) tak, aby to trvalo kratší dobu, je to vůbec možné? Děkuji mnoho krát za rady


    Přikládám ještě onen dotaz:

    SELECT DISTINCT SP68CIS AS 'Číslo pacienta',
    SP10PRI AS 'Příjmení',
    SP10JME AS 'Jméno',
    SP10ROC AS 'Rodné číslo',
    SP10POH AS 'Pohlaví - 0:Neuvedeno, 1:Muž, 2:Žena',
    SP68DAT AS 'Surgery date',
    SP68TDA2 AS 'Calcul. IOL',
    SP68DHOD AS 'Implant. IOL',
    SP45.SP45DNAD AS 'UV',
    SP45.SP45DVID AS 'Distance BV',
    SP45.SP45DSFD AS 'SF',
    SP45.SP45DCYD AS 'CYL',
    SP45.SP45DAXD AS 'axis',
    SP35.SP35NTD AS 'IOP',
    SP35.SP35CCD AS 'CCT',
    -- a tohle uz nevim jak dal udelat
    SP45tyden.SP45DNAD AS 'UV t', -- po tydnu
    SP45tyden.SP45DVID AS 'Distance BV t', -- po tydnu
    SP45tyden.SP45DSFD AS 'SF t', -- po tydnu
    SP45tyden.SP45DCYD AS 'CYL t', -- po tydnu
    SP45tyden.SP45DAXD AS 'axis t', -- po tydnu
    SP35tyden.SP35NTD AS 'IOP t', -- po tydnu
    SP35tyden.SP35CCD AS 'CCT t', -- po tydnu

    SP45mesic.SP45DNAD AS 'UV m', -- po mesici
    SP45mesic.SP45DVID AS 'Distance BV m', -- po mesici
    SP45mesic.SP45DSFD AS 'SF m', -- po mesici
    SP45mesic.SP45DCYD AS 'CYL m', -- po mesici
    SP45mesic.SP45DAXD AS 'axis m', -- po mesici
    SP35mesic.SP35NTD AS 'IOP m', -- po mesici
    SP35mesic.SP35CCD AS 'CCT m', -- po mesici

    SP68IMOD AS 'Typ čočky',
    SP60ODG,
    SP35.SP35CCD
    FROM SP10
    JOIN SP68
    ON SP68.SP68CIS = SP10.SP10CIS
    JOIN SP60
    ON SP68.SP68CIS = SP60.SP60CIS
    JOIN SP45
    ON (SP68.SP68CIS = SP45.SP45CIS AND SP68.SP68DAT = SP45.SP45DAT)
    JOIN SP35
    ON (SP68.SP68CIS = SP35.SP35CIS AND SP68.SP68DAT = SP35.SP35DAT)

    LEFT JOIN SP45 AS SP45tyden
    ON (SP68.SP68CIS = SP45tyden.SP45CIS AND
    SP45tyden.SP45DAT >= DATE_ADD(SP68.SP68DAT, INTERVAL 3 DAY) AND
    SP45tyden.SP45DAT <= DATE_ADD(SP68.SP68DAT, INTERVAL 15 DAY))
    LEFT JOIN SP35 AS SP35tyden
    ON (SP68.SP68CIS = SP35tyden.SP35CIS AND
    SP35tyden.SP35DAT >= DATE_ADD(SP68.SP68DAT, INTERVAL 3 DAY) AND
    SP35tyden.SP35DAT <= DATE_ADD(SP68.SP68DAT, INTERVAL 15 DAY))

    LEFT JOIN SP45 AS SP45mesic
    ON (SP68.SP68CIS = SP45mesic.SP45CIS AND
    SP45mesic.SP45DAT >= DATE_ADD(SP68.SP68DAT, INTERVAL 16 DAY) AND
    SP45mesic.SP45DAT <= DATE_ADD(SP68.SP68DAT, INTERVAL 50 DAY))
    LEFT JOIN SP35 AS SP35mesic
    ON (SP68.SP68CIS = SP35mesic.SP35CIS AND
    SP35mesic.SP35DAT >= DATE_ADD(SP68.SP68DAT, INTERVAL 16 DAY) AND
    SP35mesic.SP35DAT <= DATE_ADD(SP68.SP68DAT, INTERVAL 50 DAY))

    WHERE (UCASE(SP60ODG) LIKE UCASE('%tara%od%')) -- filtruji zde, ze se jedna o operaci katarakta
    AND UCASE(SP68IMOD) LIKE UCASE('%PDIFF%')

    27.1.2011 15:43 vlasta | skóre: 10 | Brno
    Rozbalit Rozbalit vše Re: Filtrování záznamů v tabulce dle data
    problem muze byt jednak v mnozstvi dat, ve spojovacich podminkach a funkcich ve where + pouzity like. Take ten distinct hodne zdrzuje v pripadech, kdy mnozina sloupcu i radku je hodne velika. Take se nabizi otazka, jake mas indexy, jestli by nejaky dalsi nepomohl...

    Jinak u tech datumu zkus pouzit klauzuli BETWEEN, je to citelnejsi(i kdyz pri tomto pojmenovani tabulek a sloupcu to moc nevytrhne).

    Muzes prozradit, na cem ta databaze slape?
    27.1.2011 17:36 kuka
    Rozbalit Rozbalit vše Re: Filtrování záznamů v tabulce dle data
    Jake mnozstvi zaznamu je v tech tabulkach? Jsou tam indexy? Pripadne jake? Co to je za databazi a na jakem hardwaru?

    Proc je tam distinct, ma to nejake vecne opodstatneni, pokud ano jake? Pokud ne tak ho vyhod, muze maskovat nejaky kartezsky soucin apod.

    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.