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íží...
včera 22:44 | Komunita

Joinup informuje, že Mnichov používá open source groupware Kolab. V srpnu byl dokončen dvouletý přechod na toto řešení. V provozu je asi 60 000 poštovních schránek. Nejenom Kolabu se věnoval Georg Greve ve své přednášce Open Source: the future for the European institutions (SlideShare) na konferenci DIGITEC 2016, jež proběhla v úterý 29. listopadu v Bruselu. Videozáznam přednášek z hlavního sálu je ke zhlédnutí na Livestreamu.

Ladislav Hagara | Komentářů: 4
včera 15:30 | Zajímavý projekt

Společnost Jolla oznámila v příspěvku Case study: Sailfish Watch na svém blogu, že naportovala Sailfish OS na chytré hodinky. Využila a inspirovala se otevřeným operačním systémem pro chytré hodinky AsteroidOS. Použita je knihovna libhybris. Ukázka ovládání hodinek na YouTube.

Ladislav Hagara | Komentářů: 6
včera 14:15 | Nová verze

Byla vydána verze 7.1.0 skriptovacího jazyka PHP používaného zejména k vývoji dynamických webových stránek. Jedná se o první stabilní verzi nejnovější větvě 7.1. Přehled novinek v dokumentaci. Podrobnosti v ChangeLogu. K dispozici je také příručka pro přechod z PHP 7.0.x na PHP 7.1.x.

Ladislav Hagara | Komentářů: 1
včera 12:55 | Nová verze

Google Chrome 55 byl prohlášen za stabilní. Nejnovější stabilní verze 55.0.2883.75 tohoto webového prohlížeče přináší řadu oprav a vylepšení (YouTube). Opraveno bylo také 36 bezpečnostních chyb. Mariusz Mlynski si například vydělal 22 500 dolarů za 3 nahlášené chyby (Universal XSS in Blink).

Ladislav Hagara | Komentářů: 4
včera 11:55 | Pozvánky

Máte rádi svobodný software a hardware nebo se o nich chcete něco dozvědět? Přijďte na 135. sraz spolku OpenAlt, který se bude konat ve čtvrtek 8. prosince od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Sraz bude tentokrát tématický. Bude retro! K vidění budou přístroje jako Psion 5mx nebo Palm Z22. Ze svobodného hardwaru pak Openmoko nebo čtečka WikiReader. Přijďte se i vy pochlubit svými legendami, nebo alespoň na pivo. Moderní hardware má vstup samozřejmě také povolen.

xkucf03 | Komentářů: 0
včera 00:10 | Nová verze

Byla vydána verze 3.2 svobodného systému pro detekci a prevenci průniků a monitorování bezpečnosti počítačových sítí Suricata. Z novinek lze zmínit například podporu protokolů DNP3 a CIP/ENIP, vylepšenou podporu TLS a samozřejmě také aktualizovanou dokumentaci.

Ladislav Hagara | Komentářů: 0
1.12. 21:00 | Nová verze

Byla vydána beta verze Linux Mintu 18.1 s kódovým jménem Serena. Na blogu Linux Mintu jsou hned dvě oznámení. První o vydání Linux Mintu s prostředím MATE a druhé o vydání Linux Mintu s prostředím Cinnamon. Stejným způsobem jsou rozděleny také poznámky k vydání (MATE, Cinnamon) a přehled novinek s náhledy (MATE, Cinnamon). Linux Mint 18.1 bude podporován až do roku 2021.

Ladislav Hagara | Komentářů: 0
1.12. 16:42 | Nová verze

Byl vydán Devuan Jessie 1.0 Beta 2. Jedná se o druhou beta verzi forku Debianu bez systemd představeného v listopadu 2014 (zprávička). První beta verze byla vydána v dubnu letošního roku (zprávička). Jedna z posledních přednášek věnovaných Devuanu proběhla v listopadu na konferenci FSCONS 2016 (YouTube, pdf).

Ladislav Hagara | Komentářů: 0
1.12. 15:16 | Komunita

Na GOG.com začal zimní výprodej. Řada zlevněných her běží oficiálně také na Linuxu. Hru Neverwinter Nights Diamond lze dva dny získat zdarma. Hra dle stránek GOG.com na Linuxu neběží. Pomocí návodu ji lze ale rozběhnout také na Linuxu [Gaming On Linux].

Ladislav Hagara | Komentářů: 1
1.12. 13:14 | Bezpečnostní upozornění

Byla vydána verze 2.7.1 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Řešeno je několik bezpečnostních problémů. Aktualizován byl především Tor Browser na verzi 6.0.7. Tor Browser je postaven na Firefoxu ESR (Extended Support Release) a právě ve Firefoxu byla nalezena a opravena vážná bezpečnostní chyba MFSA 2016-92 (CVE-2016-9079, Firefox SVG Animation

… více »
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%)
 (7%)
 (5%)
 (3%)
Celkem 761 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama

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: 264×
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.