Autor | Zpráva | ||
---|---|---|---|
table Profil * |
#1 · Zasláno: 6. 7. 2013, 16:11:15 · Upravil/a: table
Zdravím dámy a pánové.
Potřeboval bych poradit. Takto vypisuji nové řádky jen zapsané dnes: <?php $datum=date("dmY"); $result = mysql_query("SELECT * FROM `sportsdb_wins` WHERE winconf='$confid' AND DATE_FORMAT(datum,'%d%m%Y')='$datum'"); echo "Dnes se odehrálo " . mysql_num_rows($result) . " zápasů\n"; ?> V db mám zapsán datum typu datetime (např.2013-07-06 16:06:52), proto ho musím jak je vidět výše v kodu převádět. Předem děkuji za radu |
||
juriad Profil |
Nemusíš převádět, vše lze řešit přímo v DB:
SELECT COUNT(*) FROM `sportsdb_wins` WHERE DATE(datum) = CURDATE() AND … Obdobně záznamy za tento týden: SELECT COUNT(*) FROM `sportsdb_wins` WHERE WEEKOFYEAR(datum) = WEEKOFYEAR(NOW()) AND …; Projdi si funkce pro práci s datumy a časy: http://dev.mysql.com/doc/refman/5.6/en/date-and-time-functions.html A nepoužívej pro počítání funkci mysql_num_rows, pokud nepotřebuješ data všech řádků; použij v DB funkci count. Je to méně náročné na výkon, zbytečně netaháš z databáze data, která nepoužiješ. |
||
table Profil * |
#3 · Zasláno: 6. 7. 2013, 16:50:39
Velice děkuji, prostuduji si to.
|
||
Časová prodleva: 12 let
|
0