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 14:33 | Humor

    Copilot automaticky vkládal do pull requestů 'propagační tipy', reklamní text se na GitHubu objevil ve více než jedenácti tisících pull requestech. Po vlně kritiky byla tato funkce zablokována a produktový manažer Tim Rogers připustil, že umožnit Copilotovi upravovat cizí pull requesty bez vědomí autorů byla chyba.

    NUKE GAZA! 🎆 | Komentářů: 4
    včera 12:55 | Upozornění

    Je 31. března a tedy Světový den zálohování (World Backup Day). Co by se stalo, kdyby Vám právě teď odešel počítač, tablet nebo telefon, který používáte?

    Ladislav Hagara | Komentářů: 3
    včera 12:44 | Upozornění

    Digitální a informační agentura (DIA) přistupuje ke změně formátu důvěryhodného seznamu České republiky z verze TLv5 na verzi TLv6, která nastane 29. dubna 2026 v 00:00 (CET). Ke změně formátu důvěryhodných seznamů členských států (tzv. Trusted Lists) dochází na základě změn příslušné unijní legislativy. Důvěryhodné seznamy se používají v rámci informačních systémů a aplikací zejména pro účely ověřování platnosti elektronických

    … více »
    Ladislav Hagara | Komentářů: 2
    včera 05:00 | Nová verze

    Rspamd (Wikipedie), tj. open source systému pro filtrování nevyžádané pošty, byl vydán v nové major verzi 4.0.0. Přehled novinek v Changelogu.

    Ladislav Hagara | Komentářů: 1
    30.3. 23:11 | Nová verze

    SolveSpace (Wikipedie), tj. multiplatformní open source parametrický 2D/3D CAD, byl vydán v nové verzi 3.2. Přehled novinek v Changelogu na GitHubu. Vyzkoušet lze novou oficiální webovou verzi.

    Ladislav Hagara | Komentářů: 7
    30.3. 18:22 | Pozvánky

    Organizátoři Dne IPv6, tradiční akce věnované tématům spojeným s tímto protokolem, vyhlásili Call for Abstracts. Na webu konference mohou zájemci přihlašovat příspěvky o délce 20 nebo 40 minut či 10minutové lighting talky a to až do 30. dubna. Tvůrci programu uvítají návrhy přednášek z akademického i komerčního sektoru, které mohou být technického i netechnického zaměření. Den IPv6 se letos uskuteční 4. června a místem konání bude i

    … více »
    VSladek | Komentářů: 12
    30.3. 15:00 | Zajímavý software

    Euro-Office (Wikipedie) je evropský fork open source kancelářského balíku OnlyOffice. Za forkem stojí koalice firem IONOS, Nextcloud, Eurostack, XWiki, OpenProject, Soverin, Abilian a BTactic. Cílem je zajistit digitální suverenitu Evropy a snížit závislost na neevropských platformách. Projekt vznikl mimo jiné v reakci na nedávné uzavření cloudové služby OnlyOffice. OnlyOffice obviňuje Euro-Office z porušení licenčních podmínek. Na možné problémy upozorňuje i Collabora Online. Jednostranná změna licence není v pořádku.

    Ladislav Hagara | Komentářů: 27
    30.3. 05:11 | Komunita

    Byly zpracovány a na YouTube zveřejněny videozáznamy jednotlivých přednášek z letošního Installfestu.

    Ladislav Hagara | Komentářů: 0
    30.3. 00:22 | Komunita

    Během akce Arduino Days 2026 byl publikován Arduino Open Source Report 2025 (pdf) a oznámeno 7 nových produktů kompatibilních s deskou UNO Q (Arduino USB-C Power Supply, USB-C Cable, USB-C Hub, UNO Media Carrier, UNO Breakout Carrier, Bug Hopper, Modulino LED Matrix).

    Ladislav Hagara | Komentářů: 1
    29.3. 20:22 | IT novinky

    Google v pátek spustil v Česku Vyhledávání Live. Tato novinka umožňuje lidem vést plynulou konverzaci s vyhledávačem v češtině. A to prostřednictvím hlasu, nebo prostřednictvím toho, na co ukážou svým fotoaparátem či kamerou v mobilu. Rozšíření této multimodální funkce je možné díky nasazení Gemini 3.1 Flash Live, nového hlasového a audio modelu, který je od základu vícejazyčný, takže umožňuje lidem po celém světě mluvit na vyhledávač přirozeně a v jazyce, který je jim nejbližší.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (15%)
     (7%)
     (1%)
     (12%)
     (30%)
     (3%)
     (6%)
     (2%)
     (14%)
     (23%)
    Celkem 1196 hlasů
     Komentářů: 29, poslední včera 11:17
    Rozcestník

    Dotaz: Ako riesit prechod Mysql na Mysqli pripadne na inu databazu

    lukve avatar 23.10.2016 16:25 lukve | skóre: 29 | blog: lukolve | Prešov
    Ako riesit prechod Mysql na Mysqli pripadne na inu databazu
    Přečteno: 398×

    Zdravim,

     

    potrebujem radu ohladom jedneho mojho projektu. zacal som pred par rokmi programovat a vyslo to na PHP v kombinacii s MySQL + pouzivam apache pripadne ak to nahadzujem na RPI tak lighttpd. mam mensi problem a to v tom ako premigrovat klasicke Mysql na Mysqli ono to nie je nic hrozne vsak stale sa da pouzit neobjektovy mysqli zmeny su len vo funkciach minimalne, rozmyslam ale nad tym ci by nebolo lepsie prepisat vsetko do Postgresql. Celkovo PHP je dost meniaci sa jazyk, Mysql to uz je na mna moc kedze ten projekt je o trochu vecsi a ked uz si dat namahu tak nech to je nieco co ma prinos.

    skusam spravit aj db wrapper kde si budem moct vybrat co a aku databazu budem pouzivat, zatial su to len zaciatky

     


    // WARP
    // DB WRAPPER
    //
    // 0 - Mysql
    // 1 - Mysqli
    // 2 - Postgresql

    var $warp = 0;
    var $con;

    /*db_connect*/
    public function warp_connect($host,$user,$pass) {
    //return mysql_connect($host,$user,$pass);
    switch ($this->warp) {
    case 0:
    return mysql_connect($host,$user,$pass);
    break;
    case 1:
    $co = mysqli_connect($host,$user,$pass,$this->table);
    // Check connection
    if (mysqli_connect_errno())
    {
    echo "Failed to connect to MySQL: " . mysqli_connect_error();
    }
    return $co;
    break;
    default:
    // postgree not implemented yet
    break;
    }
    }

    /*error*/
    public function warp_error() {
    //return mysql_error();
    switch ($this->warp) {
    case 0:
    return mysql_error();
    break;
    case 1:
    return mysqli_error($this->con);
    break;
    default:
    // postgree not implemented yet
    break;
    }
    }

    /*query*/
    public function warp_query($que) {
    //return mysql_query($que);
    switch ($this->warp) {
    case 0:
    return mysql_query($que);
    break;
    case 1:
    return mysqli_query($this->con, $que);
    break;
    default:
    // postgree not implemented yet
    break;
    }
    }

    /*num_fields*/
    public function warp_num_fields($res) {
    //return mysql_num_fields($res);
    switch ($this->warp) {
    case 0:
    return mysql_num_fields($res);
    break;
    case 1:
    return mysqli_num_fields($res);
    break;
    default:
    // postgree not implemented yet
    break;
    }
    }

    /*num_fields*/
    public function warp_num_rows($res) {
    //return mysql_num_rows($res);
    switch ($this->warp) {
    case 0:
    return mysql_num_rows($res);
    break;
    case 1:
    return mysqli_num_rows($res);
    break;
    default:
    // postgree not implemented yet
    break;
    }
    }

    /*fetch_assoc*/
    public function warp_fetch_assoc($res) {
    //return mysql_fetch_assoc($res);
    switch ($this->warp) {
    case 0:
    return mysql_fetch_assoc($res);
    break;
    case 1:
    return mysqli_fetch_assoc($res);
    break;
    default:
    // postgree not implemented yet
    break;
    }
    }

    /*fetch_row*/
    public function warp_fetch_row($res) {
    //return mysql_fetch_row($res);
    switch ($this->warp) {
    case 0:
    return mysql_fetch_row($res);
    break;
    case 1:
    return mysqli_fetch_row($res);
    break;
    default:
    // postgree not implemented yet
    break;
    }
    }

    /*select_db*/
    public function warp_select_db($name) {
    //return mysql_select_db($name);
    switch ($this->warp) {
    case 0:
    return mysql_select_db($name);
    break;
    case 1:
    return mysqli_select_db($this->con, $name);
    break;
    default:
    // postgree not implemented yet
    break;
    }
    }

    /*real_escape_string*/
    public function warp_real_escape_string($res) {
    //return mysql_real_escape_string($res);
    switch ($this->warp) {
    case 0:
    return mysql_real_escape_string($res);
    break;
    case 1:
    return mysqli_real_escape_string($this->con, $res);
    break;
    default:
    // postgree not implemented yet
    break;
    }
    }

    linux user more than 20y

    Odpovědi

    23.10.2016 18:33 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: Ako riesit prechod Mysql na Mysqli pripadne na inu databazu
    MySQLi je jen novější ovladač pro MySQL. Proto byl ten starý ovladač před 4 lety zavržen, aby teď mohl být odebrán.

    Nejlepší je přejít na PDO, které je možné použít jednotným způsobem pro mnoho databází: MySQL, PosgreSQL, SQLite, ...
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    lukve avatar 23.10.2016 18:54 lukve | skóre: 29 | blog: lukolve | Prešov
    Rozbalit Rozbalit vše Re: Ako riesit prechod Mysql na Mysqli pripadne na inu databazu

    Kit> dakujem uz tomu rozumiem takze PDO je nezavisle lebo je objektove aj u mysqli sa vyuzivaju prefixi ze mysqli_query a to PDO je nezavisle ale ako sa potom riesia samotne sql dotazy kedze Mysql pouziva trochu zlozitejsie a Postgree podporuje len ANSI jednoduchy syntax..

     

    aby bolo jasne dovod preco som sa pustil do tohto wrapperu je ten ze moj projekt je sice velky ale pouzivam len jednoduche dotazy takze prepisat do postgree nebude aspon si to myslim "velke sialenstvo"

    linux user more than 20y
    23.10.2016 19:53 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: Ako riesit prechod Mysql na Mysqli pripadne na inu databazu
    SQL dotazy jsou pro jednotlivé databáze samozřejmě rozdílné. Ovšem PDO si už poradí např. s odlišným quotováním, takže to zjednodušuje sestavování dotazů.

    Doporučuji však pro každou databázi udělat vlastní malou nadstavbu - ty mé se jmenují MyPDO, LitePDO a PgPDO. Mají stejné rozhraní jako PDO, jen o něco málo rozšířené pro větší pohodlí (líné otevírání DB a některé SQL dotazy). Při otevírání pak vyberu jednu z těch tří nadstaveb, otevřu s ní databázi, uložím do proměnné $db a dál už s ní pracuji jednotně - zbytek aplikace netuší, kterou databázi jsem otevřel. Je ti jistě jasné, co asi bude dělat příkaz $db->insert('tabulka', $data);
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.

    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.