Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 03-01-2008, 01:15   #1
bouncey2k
Member
 
Iscritto dal: Jan 2006
Messaggi: 271
[PHP, MySQL] problematica mysql_num_rows

Ho un ciclo che mi mostra alcuni articoli del database

Codice PHP:
$select mysql_query ("SELECT * FROM articoli LIMIT 0,5"$db);
while (
$record mysql_fetch_array ($select))
{
echo 
"<p>{$record['testo']}</p>";

in un'altra tabella "commenti" (nello stesso database) ho i commenti agli articoli; vorrei inserire il loro numero sotto il $record['testo']:
Codice PHP:
{
echo 
"<p>{$record['testo']}</p>";
echo 
"<p>(n.commenti $num_righe)</p>";

Per fare questo ho scritto due righe fuori dal ciclo while:

Codice PHP:
$select_count mysql_query ("SELECT * FROM commenti WHERE link_b = '$id' "$db);
$num_righe mysql_num_rows($select_count); 
Solo che non funziona perché pare che il while legga l'altra $select e non quella del conteggio righe.

Ho provato il codice senza il while e il numero delle righe me le legge.
Come potrei fare?
bouncey2k è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2008, 01:27   #2
vizzz
Senior Member
 
L'Avatar di vizzz
 
Iscritto dal: Mar 2006
Città: Bergamo
Messaggi: 2499
sapere per esteso la struttura delle tabelle chiarirebbe le cose, comuque ad occhio una soluzione veloce (forse non la migliore) sarebbe per ogni articolo di cui mostri il testo effettuare la query per ottenere il numero di commenti.
sapendo la struttura completa magari è possibile fare la stessa cosa con una query sola utilizzando una join.
__________________
ho concluso con: kvegeta, doctordb, Leland Gaunt.
vizzz è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2008, 11:00   #3
kk3z
Senior Member
 
L'Avatar di kk3z
 
Iscritto dal: Nov 2003
Messaggi: 980
Codice PHP:
$select mysql_query ("SELECT a.*, COUNT(c.id) num_commenti
FROM articoli a
LEFT JOIN commenti c ON c.link_b  = a.id
GROUP BY a.id
LIMIT 0,5"
$db);
while (
$record mysql_fetch_array ($select))
{
echo 
"<p>{$record['testo']}</p>";
echo 
"<p>(n.commenti $record['num_commenti'])</p>";

a.id è l'id dell'articolo
kk3z è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2008, 14:41   #4
bouncey2k
Member
 
Iscritto dal: Jan 2006
Messaggi: 271
Quote:
Originariamente inviato da kk3z Guarda i messaggi
Codice PHP:
$select mysql_query ("SELECT a.*, COUNT(c.id) num_commenti
FROM articoli a
LEFT JOIN commenti c ON c.link_b  = a.id
GROUP BY a.id
LIMIT 0,5"
$db);
while (
$record mysql_fetch_array ($select))
{
echo 
"<p>{$record['testo']}</p>";
echo 
"<p>(n.commenti $record['num_commenti'])</p>";

a.id è l'id dell'articolo
Che cosa stanno a significare quei "a" e "c"? E quel "FROM articoli a" ?
bouncey2k è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2008, 16:04   #5
kk3z
Senior Member
 
L'Avatar di kk3z
 
Iscritto dal: Nov 2003
Messaggi: 980
a, c e num_commenti sono alias, cioè un altro modo di identificare una tabella (articoli -> a, commenti -> c) o un campo (COUNT(commenti.id) -> num_commenti). Se non ti è chiaro, ecco altre 2 soluzioni identiche:
Codice:
SELECT a.*, COUNT(c.id) AS num_commenti
FROM articoli AS a
LEFT JOIN commenti AS c ON c.link_b  = a.id
GROUP BY articoli.id
LIMIT 0,5
Codice:
SELECT articoli.*, COUNT(commenti.id)
FROM articoli
LEFT JOIN commenti ON commenti.link_b  = articoli.id
GROUP BY articoli.id
LIMIT 0,5
kk3z è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2008, 17:32   #6
bouncey2k
Member
 
Iscritto dal: Jan 2006
Messaggi: 271
adesso funziona, però GROUP BY articoli.id me li ordina in maniere crescente, io vorrei che me li ordinasse in maniera decrescente.

Ho provato con un ORDER BY articoli.id DESC ma non funziona, addirittura spariscono gli articoli!
bouncey2k è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2008, 18:19   #7
kk3z
Senior Member
 
L'Avatar di kk3z
 
Iscritto dal: Nov 2003
Messaggi: 980
Sicuramente metti l'ORDER BY nel posto sbagliato, e poi non controlli se la query dà errore o no. L'ORDER BY va dopo il GROUP BY e prima del LIMIT:
Codice:
SELECT a.*, COUNT(c.id) num_commenti
FROM articoli a
LEFT JOIN commenti c ON c.link_b  = a.id
GROUP BY a.id
ORDER BY a.id DESC
LIMIT 0,5
kk3z è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2008, 18:40   #8
bouncey2k
Member
 
Iscritto dal: Jan 2006
Messaggi: 271
Grazie. Adesso funziona tutto.
bouncey2k è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
Finalmente un portatile tuttofare Lenovo...
Xiaomi 17: la versione Global avrà una b...
4 TV da 55" in sconto: da 299€ a 99...
Altro che crisi: la PlayStation 6 potreb...
Per iniziare e non solo: DJI Neo a 149€,...
Il nuovo MacBook entry level potrebbe es...
PlayStation annuncia lo State of Play di...
Funzionalità top a un prezzo acce...
Lo strumento per gli aggiornamenti autom...
Imperdibile sconto sul roborock Saros Z7...
Google Pixel 10, altri 100€ di sconto su...
Chip sotto i 2 nanometri, l'Europa alza ...
La smart meno smart di tutte: #6 in azio...
Red Hat Enterprise Linux sbarca su AWS E...
Addio alle migliaia di cicli e anni di t...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 07:59.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v