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í
×
    včera 22:33 | Nová verze

    Oficiálně byl vydán Android 16. Detaily na blogu a stránkách věnovaných vývojářům.

    Ladislav Hagara | Komentářů: 1
    včera 14:33 | Nová verze

    Byla vydána nová verze 14.3 svobodného unixového operačního systému FreeBSD. Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 14:00 | Upozornění

    CSIRT.CZ upozorňuje, že na základě rozhodnutí federálního soudu ve Spojených státech budou veškeré konverzace uživatelů s ChatGPT uchovávány. Včetně těch smazaných.

    Ladislav Hagara | Komentářů: 8
    včera 13:44 | Pozvánky

    Ač semestr ve škole právě končí, bastlíři ze studentského klubu Silicon Hill neodpočívají a opět se jako každý měsíc hlásí s pravidelným bastlířským setkáním Virtuální Bastlírna, kde si můžete s ostatními techniky popovídat jako u piva o novinkách, o elektronice, softwaru, vědě, technice obecně, ale také o bizarních tématech, která se za poslední měsíc na internetu vyskytla.

    Z novinek za zmínku stojí Maker Faire, kde Pájeníčko předvedlo … více »
    bkralik | Komentářů: 0
    včera 04:44 | Zajímavý software

    Na WWDC25 byl představen balíček Containerization a nástroj container pro spouštění linuxových kontejnerů na macOS. Jedná se o open source software pod licencí Apache 2.0 napsaný v programovacím jazyce Swift.

    Ladislav Hagara | Komentářů: 1
    včera 02:00 | IT novinky

    Do 16. června do 19:00 běží na Steamu přehlídka nadcházejících her Festival Steam Next | červen 2025 doplněná demoverzemi, přenosy a dalšími aktivitami. Demoverze lze hrát zdarma.

    Ladislav Hagara | Komentářů: 0
    9.6. 21:44 | IT novinky

    Apple na své vývojářské konferenci WWDC25 (Worldwide Developers Conference, keynote) představil řadu novinek: designový materiál Liquid Glass, iOS 26, iPadOS 26, macOS Tahoe 26, watchOS 26, visionOS 26, tvOS 26, nové funkce Apple Intelligence, …

    Ladislav Hagara | Komentářů: 1
    9.6. 20:44 | Komunita

    Organizátoři konference LinuxDays 2025, jež proběhne o víkendu 4. a 5. října 2025 v Praze na FIT ČVUT, spustili přihlašování přednášek (do 31. srpna) a sběr námětů na zlepšení.

    Ladislav Hagara | Komentářů: 0
    9.6. 19:11 | Nová verze

    Po roce byla vydána nová stabilní verze 25.6.0 svobodného multiplatformního multimediálního přehrávače SMPlayer (Wikipedie).

    Ladislav Hagara | Komentářů: 0
    9.6. 12:55 | IT novinky

    DNS4EU, tj. evropská infrastruktura služeb DNS založená na vysoce federovaném a distribuovaném ochranném ekosystému, byla spuštěna v testovacím režimu [𝕏]. Na výběr je 5 možností filtrování DNS.

    Ladislav Hagara | Komentářů: 20
    Jaký je váš oblíbený skriptovací jazyk?
     (55%)
     (32%)
     (7%)
     (2%)
     (0%)
     (0%)
     (3%)
    Celkem 242 hlasů
     Komentářů: 16, poslední 8.6. 21:05
    Rozcestník

    Dotaz: MySQL LIKE nebo REGEXP

    25.2.2015 17:35 Andy
    MySQL LIKE nebo REGEXP
    Přečteno: 847×
    Ahoj, nevim jestli jsem ve spravne kategorii ale problem je nasledujici: Mam v databazi 2 radky z asi takovymto obsahem
    7|1#9|1,5,7#10|2,4,51#
    7|1#9|1,4,5#10|1,3,38#
    
    • # - je dase rict rozdelovac pole,
    • hodnota pred | je jakysi ID
    • a hodnoty mezi | a # jsou vzdy cisla oddelena carkou
    ucelem je vybrat pouze radek z ID 9 a hodnotou 4 coz je druhy radek Zkousel jsem to pomoci LIKE
    sloupec LIKE "9|4#%" OR 
    sloupec LIKE "%#9|4#%" OR 
    sloupec LIKE "%#9|%,4#%" OR 
    sloupec LIKE "%#9|%,4,%#%" OR 
    sloupec LIKE "%#9|4,%#%"
    ale to vybere oba sloupce, chtel jsem to zkusit pomoci REGEXP ale priznam se ze regulerni vyrazy jsem nikdy neosilil.

    Poradil by nekdo prosim nejake reseni?

    Odpovědi

    wamba avatar 25.2.2015 19:09 wamba | skóre: 38 | blog: wamba
    Rozbalit Rozbalit vše Re: MySQL LIKE nebo REGEXP
    (Perl-)regexp by mohl vypadat třeba takhle: \b9[|][\d,]*\b4\b
    This would have been so hard to fix when you don't know that there is in fact an easy fix.
    26.2.2015 14:08 Andy
    Rozbalit Rozbalit vše Re: MySQL LIKE nebo REGEXP
    Diky za nakopnuti po par pokusech mi z toho vylezlo pro mysql REGEXP '9[|][^#]*4' a vypada to ze funguje jak ma
    10.3.2015 08:54 blondak | skóre: 36 | blog: Blondak | Čáslav
    Rozbalit Rozbalit vše Re: MySQL LIKE nebo REGEXP
    tohle nebude fungovat asi úplně podle představy matchne to třeba i 19|14, ..

    Mělo by to být spíš měco jako '(^|#)9\|(4[,#]|([\d]+,)+4[,#])'
    Každý problém ma své logické, snadno pochopitelné nesprávné řešení.
    10.3.2015 13:35 blondak | skóre: 36 | blog: Blondak | Čáslav
    Rozbalit Rozbalit vše Re: MySQL LIKE nebo REGEXP
    lze ještě zkrátit na
    (^|#)9\|(([\d]+,)*4[,#])
    Každý problém ma své logické, snadno pochopitelné nesprávné řešení.
    25.2.2015 19:37 Filip Jirsák
    Rozbalit Rozbalit vše Re: MySQL LIKE nebo REGEXP
    Chcete to dělat jednorázově, nebo opakovaně? V druhém případě se určitě vyplatí ta data normalizovat, tj. rozparsovat je a uložit do samostatných tabulek. K tomu relační databáze slouží.
    26.2.2015 14:10 Andy
    Rozbalit Rozbalit vše Re: MySQL LIKE nebo REGEXP
    Opakovan ale ne tak casto abych kvuli tomu predelaval cely system ...
    26.2.2015 17:24 Filip Jirsák
    Rozbalit Rozbalit vše Re: MySQL LIKE nebo REGEXP
    Myslím, že by nebylo nutné předělávat celý systém - stačil by trigger, který by při zápisu do té zdrojové tabulky data rozparsoval a zapsal do dalších tabulek. Podle mne je to asi tak stejně pracné, jako vyrábět ten dotaz, který vyhledává v těch nestrukturovaných datech.
    rADOn avatar 9.3.2015 16:55 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: MySQL LIKE nebo REGEXP
    Ze se namahas… Jestli tam ma nejake netrivialni mnozstvi dat tak ho to velice rychle donuti samo :-)
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    Josef Kufner avatar 14.3.2015 14:01 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: MySQL LIKE nebo REGEXP
    Případně si tu jednu zajímavou hodnotu vytáhnout do druhého sloupečku a nechat zbytek jako blob, se kterým se nijak nepracuje. To celkem běžně dělám se složitějšími daty v JSON, pokud (!) s nimi na úrovni databáze nepracuji. Mít jeden nebo několik málo sloupečků z takových dat vypočítávaných pro potřeby databáze je celkem praktické a ušetří to kopec práce.
    Hello world ! Segmentation fault (core dumped)
    xkucf03 avatar 15.3.2015 12:14 xkucf03 | skóre: 49 | blog: xkucf03
    Rozbalit Rozbalit vše Re: MySQL LIKE nebo REGEXP

    Doporučuji přečíst si něco o návrhu datového modelu a normalizaci. Je to velice užitečné a ušetříš si tím spoustu práce.

    Jestliže s těmi daty chceš pracovat na úrovni databáze, tak ty hrůzy, co tam máš, je potřeba rozbít na víc sloupců případně tabulek – abys tam měl atomické hodnoty.

    Pokud by to z povahy dat resp. jejich struktury nešlo (většinou to jde), tak použij nějaký datový typ, který ti umožní uložit víc hodnot/strukturu do jednoho sloupce (XML, pole atd.), se kterým tvůj SŘBD umí pracovat a nabízí pro něj funkce/operátory.

    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-DK, Relational pipes

    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.