Archívum - Dec 17, 2012
Több időzónás időpontok tárolása adatbázisban, statisztika és teljesítmény
Egy időmérő programot kellene csinálni, tehát mérni kellene, hogy ki, mettől-meddig és mit csinált, ebből pedig aztán statisztikákat készíteni, mindezt különböző időzónákban. Felmerült kérdések:
MySQL-ben DATETIME vs TIMESTAMP vs INT vs kombinálás?
Van itt egy cikk: http://gpshumano.blogs.dri.pt/2009/07/06/mysql-datetime-vs-timestamp-vs-int-performance-and-benchmarking-with-myisam/ Következtetéseim:
DATETIME: Gyorsabb, mint a TIMESTAMP, emberileg olvasható kódot eredményez, statisztika készítéshez használhatóak a MySQL beépített dátumkezelő függvényei, ellentétben az INT-tel. Tehát anélkül, hogy matemateikailag kellene kiszámolgatni és új értékeket képezni, lehet "group by"-olni napokra: GROUP BY DAY(datum). Nehézkes viszont összeszámolni, hogy egy-egy feladattal mennyi idő ment el (lásd INT). Továbbá csak program oldalon lehet az időzónát kezelni, mindenképpen ott konvertálni kell, ez megint csak megnehezíti, amikor össze kell számolni, hogy adott napon mennyit dolgozott az illető.
TIMESTAMP: Ez is olvasható kódot eredményez, használhatóak rá a dátum fv-ek. A különbség a DATETIME-hoz képest, hogy egyrészt lassabb a cikk szerint, ugyanakkor automatikusan lekezeli az időzónákat (és kevesebb helyet foglal, de ez most nem tűnik relevánsnak). SET time_zone = ... -nal minden kapcsolatnál be lehet állítani és akkor mindenféle macera nélkül lehet GROUP BY-olni megint csak. Hátrány még, hogy a Doctrine nem támogatja alapból ezt az oszlop típust.
INT: Ha nem bízzuk a MySQL-re lekérdezésben az időbélyeg számítást, akkor a leggyorsabb. Viszont nem használhatóak a beépített dátum függvények, nekem kell a lekérdezésekben matematikai műveletekkel, osztásokkal és kerekítésekkel kiszámolni, hogy egy adott időbélyeg melyik napnak felel meg.
MySQL-ben DATETIME vs TIMESTAMP vs INT vs kombinálás?
Van itt egy cikk: http://gpshumano.blogs.dri.pt/2009/07/06/mysql-datetime-vs-timestamp-vs-int-performance-and-benchmarking-with-myisam/ Következtetéseim:
DATETIME: Gyorsabb, mint a TIMESTAMP, emberileg olvasható kódot eredményez, statisztika készítéshez használhatóak a MySQL beépített dátumkezelő függvényei, ellentétben az INT-tel. Tehát anélkül, hogy matemateikailag kellene kiszámolgatni és új értékeket képezni, lehet "group by"-olni napokra: GROUP BY DAY(datum). Nehézkes viszont összeszámolni, hogy egy-egy feladattal mennyi idő ment el (lásd INT). Továbbá csak program oldalon lehet az időzónát kezelni, mindenképpen ott konvertálni kell, ez megint csak megnehezíti, amikor össze kell számolni, hogy adott napon mennyit dolgozott az illető.
TIMESTAMP: Ez is olvasható kódot eredményez, használhatóak rá a dátum fv-ek. A különbség a DATETIME-hoz képest, hogy egyrészt lassabb a cikk szerint, ugyanakkor automatikusan lekezeli az időzónákat (és kevesebb helyet foglal, de ez most nem tűnik relevánsnak). SET time_zone = ... -nal minden kapcsolatnál be lehet állítani és akkor mindenféle macera nélkül lehet GROUP BY-olni megint csak. Hátrány még, hogy a Doctrine nem támogatja alapból ezt az oszlop típust.
INT: Ha nem bízzuk a MySQL-re lekérdezésben az időbélyeg számítást, akkor a leggyorsabb. Viszont nem használhatóak a beépített dátum függvények, nekem kell a lekérdezésekben matematikai műveletekkel, osztásokkal és kerekítésekkel kiszámolni, hogy egy adott időbélyeg melyik napnak felel meg.
Android Facebook Publish Stream
Sziasztok!
Épp az Android -os fejlesztést próbálom felfedezni, s első körben annyit szeretnék elérni, hogy a facebook -on akarok egyet postolni egy alkalmazás segítségével. Addig el is jutottam, hogy elfogadtatom az alkalmazást. Benne is van a publish_stream a scope -ban, de az a post semmiért se akar kimenni.
Épp az Android -os fejlesztést próbálom felfedezni, s első körben annyit szeretnék elérni, hogy a facebook -on akarok egyet postolni egy alkalmazás segítségével. Addig el is jutottam, hogy elfogadtatom az alkalmazást. Benne is van a publish_stream a scope -ban, de az a post semmiért se akar kimenni.
Készülődnék egy állásinterjúra...
Előfordulhat (még nem kaptam megerősítést, csak ígéretet), hogy jövő év elején lesz egy állás interjúm, linuxos rendszergazdaként.
Erre próbálok valamennyire felkészülni, de elég zűrös a dolog. Korábban is rendszergazda voltam, csakhogy linuxokkal elsősorban hobbiból foglalkoztam, a VMS ismereteimmel meg nem megyek sokra ezen a területen, amit meg HPUX-ból tanultam, azt kb. el is felejtettem mostanra.
Szóval ezügyben szeretnék időnként kérdezősködni, ha a törzsközönségnek nem okozok vele gondot (mivel totál offtopik a téma)
Most két dologgal vagyok elakadva:
1. Ha linuxon tükrözni (RAID-1) akarok diszkeket, miért jó, hogy nem a fizikai diszket tükrözöm, hanem a partíciókat? OK, valamivel rugalmasabban kezelhető, ugyanakkor van egy olyan érzésem, hogy ezzel jelentősen ront(hat)om a performanciát.
Azt úgy nagyjából sejtem, hogy LVM-et csak végszükség esetén szabad bevetni e célra, mert iszonyatosan lassú (ex kollégák tapasztalata valami HP-s diszk rendszeren, RedHat linuxokkal - ők maradtak a hardveres RAID mellett)
2. Clusteres témában mi az, aminek érdemes utánanézni? Úgy öt éve, HPUX-on még csak olyan megoldásunk volt, hogy failover módban működtek a szolgáltatások. Ha kidőlt a cluster egy tagja, akkor a rajta futó service-ek egyszerűen elindultak valamelyik másik node-on. VMS-en meg már húsz éve is párhuzamosan működhetett minden, az összes node-on, közösen használt diszkekkel. Itt igazából az érdekelne, hogy milyen kulcsszavakra érdemes keresni, a neten mi az, amit valóban érdemes átlapozni? Elég sokféle HA megoldást találtam a múltkor (jól látom? Az sem mindegy, hogy RedHat c. Debian alapú a rendszerem?) és nem vagyok biztos benne, hogy egyformán elterjedtek, használhatóak.
Erre próbálok valamennyire felkészülni, de elég zűrös a dolog. Korábban is rendszergazda voltam, csakhogy linuxokkal elsősorban hobbiból foglalkoztam, a VMS ismereteimmel meg nem megyek sokra ezen a területen, amit meg HPUX-ból tanultam, azt kb. el is felejtettem mostanra.
Szóval ezügyben szeretnék időnként kérdezősködni, ha a törzsközönségnek nem okozok vele gondot (mivel totál offtopik a téma)
Most két dologgal vagyok elakadva:
1. Ha linuxon tükrözni (RAID-1) akarok diszkeket, miért jó, hogy nem a fizikai diszket tükrözöm, hanem a partíciókat? OK, valamivel rugalmasabban kezelhető, ugyanakkor van egy olyan érzésem, hogy ezzel jelentősen ront(hat)om a performanciát.
Azt úgy nagyjából sejtem, hogy LVM-et csak végszükség esetén szabad bevetni e célra, mert iszonyatosan lassú (ex kollégák tapasztalata valami HP-s diszk rendszeren, RedHat linuxokkal - ők maradtak a hardveres RAID mellett)
2. Clusteres témában mi az, aminek érdemes utánanézni? Úgy öt éve, HPUX-on még csak olyan megoldásunk volt, hogy failover módban működtek a szolgáltatások. Ha kidőlt a cluster egy tagja, akkor a rajta futó service-ek egyszerűen elindultak valamelyik másik node-on. VMS-en meg már húsz éve is párhuzamosan működhetett minden, az összes node-on, közösen használt diszkekkel. Itt igazából az érdekelne, hogy milyen kulcsszavakra érdemes keresni, a neten mi az, amit valóban érdemes átlapozni? Elég sokféle HA megoldást találtam a múltkor (jól látom? Az sem mindegy, hogy RedHat c. Debian alapú a rendszerem?) és nem vagyok biztos benne, hogy egyformán elterjedtek, használhatóak.
Swipe event érzékelés
Sziasztok!
Egy weboldal mobilos verzióját fejlesztem épp. Vannak cikkek ezen az oldalon és egy cikk több oldalból áll általában. A mobilos verzióban úgy kéne ennek működnie, hogy ha a #content div fölött balra swipe-ol a user, akkor töltse be a következő oldalt, ha pedig jobbra, akkor az előző oldalt. Egészen egyszerű is lenne az egyszeri fejlesztő élete, ha nem lenne egy szép bug a böngészőben/androidban. Workaround persze van: megkell hívni az event.preventDefault metódust. Ezzel azonban az a probléma, hogy kinagyított oldal esetén gyakorlatilag nem működik sem a nagyítás/kicsinyítés, sem a mozgatás. Egyelőre úgy sikerült csak megoldanom az oldalváltást, hogy csak akkor vált, ha az oldal nincs kinagyítva. Ez így nem a legszebb megoldás, így ha valakinek van ötlete a probléma megoldására, ne tartsa magában!
Egy weboldal mobilos verzióját fejlesztem épp. Vannak cikkek ezen az oldalon és egy cikk több oldalból áll általában. A mobilos verzióban úgy kéne ennek működnie, hogy ha a #content div fölött balra swipe-ol a user, akkor töltse be a következő oldalt, ha pedig jobbra, akkor az előző oldalt. Egészen egyszerű is lenne az egyszeri fejlesztő élete, ha nem lenne egy szép bug a böngészőben/androidban. Workaround persze van: megkell hívni az event.preventDefault metódust. Ezzel azonban az a probléma, hogy kinagyított oldal esetén gyakorlatilag nem működik sem a nagyítás/kicsinyítés, sem a mozgatás. Egyelőre úgy sikerült csak megoldanom az oldalváltást, hogy csak akkor vált, ha az oldal nincs kinagyítva. Ez így nem a legszebb megoldás, így ha valakinek van ötlete a probléma megoldására, ne tartsa magában!
Egyszerűbb fórum készítésénél fellépett cikluson belüli session probléma.
Van egy egyszerűbb fórumom amit készítettem.
Ez témákból és az azon belül létrejövő hozzászólásokból áll. Tehát nincsen egyéb módon csoportosítva csak amolyan a téma a kérdés és a hozzászólás a hozzá tartozó válaszok. A fórum témáit (a kérdéseket) egy topik nevű táblában tárolom. Itt van néhány adat (id, a kérdés címe, a hozzá tartozó megjegyzés rovat stb...) , a hozzászólások pedig a fórum táblámban (id, hozzászóló felhasználó neve, tid= az az id amelyik topikhoz tartozik, stb...).
Mivel közel sem vagyok profi így megpróbáltam valahogyan összerakni azzal az ismerettel amit a neten szereztem. Két sessiont hoztam létre amely közül az egyik a topik id-t tárolja bizonyos kapcsolódási pontokon, egy másik pedig a felhasználó id-jét. Ezekre hivatkozok többször.
Jelenleg töklletesen működne CSAK mégse. Vagyis megjelenik a kérdések listázva az adatbázisomból úgy ahogyan én szeretném. A megnyitás gombbal pedig megnyitom a hozzászólást ahová szépen úgy tudok hozzászólni amennyiben bejelentkezek, ahogyan én szeretnék. A hiba az, hogy bármelyik kérdés megnyitására is kattintok ugyan úgy az utolsó kilistázandót nyitja meg és csak ahoz tudok hozzászólni. Rájöttem, hogy az a hiba, hogy a cikluson belül ha a megnyitás gombra kattintok akkor nem csak az aktuális kérdéshez vezeti le hogy session[tid] egyenlő legyen az aktuális topik id-vel, hanem az összessel sorban így nyilván valóan mindig az utolsó megjegyzett lesz az aktuális. Mivel fordított sorrendben iratom ki, hogy mindig a legfrissebbet láthassam így ez mindig az első hozzászólás lesz. Kicseréltem, átcserélte, összecseréltem, így-úgy kiírattam, úgy írattam, átírattam... Nem megy.
Tudna valaki segíteni nekem erre a problémára?
[colorer=php]<?php
session_start();
include 'connect.php';
header("Content-Type: text/html; charset=utf-8");
$ker= mysql_query("SELECT * FROM `topik` WHERE `delete` = '0' ORDER BY `id` DESC");
while($top = mysql_fetch_array($ker))
{
echo '<p>Topik:</p>
Ez témákból és az azon belül létrejövő hozzászólásokból áll. Tehát nincsen egyéb módon csoportosítva csak amolyan a téma a kérdés és a hozzászólás a hozzá tartozó válaszok. A fórum témáit (a kérdéseket) egy topik nevű táblában tárolom. Itt van néhány adat (id, a kérdés címe, a hozzá tartozó megjegyzés rovat stb...) , a hozzászólások pedig a fórum táblámban (id, hozzászóló felhasználó neve, tid= az az id amelyik topikhoz tartozik, stb...).
Mivel közel sem vagyok profi így megpróbáltam valahogyan összerakni azzal az ismerettel amit a neten szereztem. Két sessiont hoztam létre amely közül az egyik a topik id-t tárolja bizonyos kapcsolódási pontokon, egy másik pedig a felhasználó id-jét. Ezekre hivatkozok többször.
Jelenleg töklletesen működne CSAK mégse. Vagyis megjelenik a kérdések listázva az adatbázisomból úgy ahogyan én szeretném. A megnyitás gombbal pedig megnyitom a hozzászólást ahová szépen úgy tudok hozzászólni amennyiben bejelentkezek, ahogyan én szeretnék. A hiba az, hogy bármelyik kérdés megnyitására is kattintok ugyan úgy az utolsó kilistázandót nyitja meg és csak ahoz tudok hozzászólni. Rájöttem, hogy az a hiba, hogy a cikluson belül ha a megnyitás gombra kattintok akkor nem csak az aktuális kérdéshez vezeti le hogy session[tid] egyenlő legyen az aktuális topik id-vel, hanem az összessel sorban így nyilván valóan mindig az utolsó megjegyzett lesz az aktuális. Mivel fordított sorrendben iratom ki, hogy mindig a legfrissebbet láthassam így ez mindig az első hozzászólás lesz. Kicseréltem, átcserélte, összecseréltem, így-úgy kiírattam, úgy írattam, átírattam... Nem megy.
Tudna valaki segíteni nekem erre a problémára?
[colorer=php]<?php
session_start();
include 'connect.php';
header("Content-Type: text/html; charset=utf-8");
$ker= mysql_query("SELECT * FROM `topik` WHERE `delete` = '0' ORDER BY `id` DESC");
while($top = mysql_fetch_array($ker))
{
echo '<p>Topik:</p>
Zend Framework elefántot valaki?
Sziasztok,
Páran rendelünk Zend Framework elefántot, szeretnénk kicsit faragni az áron, ezért 10-ig beszállhat, akit érdekel, eddig 5-en vagyunk.
Sajnos nem kék, nem PHP-s, de azért a semminél jobb ez is :)
Bp-n belül oda tudom adni, postázással nem szeretnék foglalkozni.
Maholnap lehet jelentkezni, mert leadnám a rendelést, priviben, vagy akár itt.
http://elephpants.dasprids.de/
Árak:
"Price : 8.36 x 4 = 33.44 euro
Shipping : 28 euro
total : 61.44 euro
In addition, if you order up to 10 elephpants, shipping fees remain the same"
■ Páran rendelünk Zend Framework elefántot, szeretnénk kicsit faragni az áron, ezért 10-ig beszállhat, akit érdekel, eddig 5-en vagyunk.
Sajnos nem kék, nem PHP-s, de azért a semminél jobb ez is :)
Bp-n belül oda tudom adni, postázással nem szeretnék foglalkozni.
Maholnap lehet jelentkezni, mert leadnám a rendelést, priviben, vagy akár itt.
http://elephpants.dasprids.de/
Árak:
"Price : 8.36 x 4 = 33.44 euro
Shipping : 28 euro
total : 61.44 euro
In addition, if you order up to 10 elephpants, shipping fees remain the same"