Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando
Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando
Abbiamo giocato a lungo a Battlefield 6, abbiamo provato tutte le modalità multiplayer, Redsec, e le numerose personalizzazioni. In sintesi, ci siamo concentrati su ogni aspetto del titolo per comprendere al meglio uno degli FPS più ambiziosi della storia dei videogiochi e, dopo quasi due mesi, abbiamo tirato le somme. In questo articolo, condividiamo con voi tutto ciò che è Battlefield 6, un gioco che, a nostro avviso, rappresenta esattamente ciò che questo genere attendeva da tempo
Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare
Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare
Abbiamo messo alla prova il drone Antigravity A1 capace di riprese in 8K a 360° che permette un reframe in post-produzione ad eliche ferme. Il concetto è molto valido, permette al pilota di concentrarsi sul volo e le manovre in tutta sicurezza e decidere con tutta tranquillità come gestire le riprese. La qualità dei video, tuttavia, ha bisogno di uno step in più per essere competitiva
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Dopo oltre 4 anni si rinnova la serie Sony Alpha 7 con la quinta generazione, che porta in dote veramente tante novità a partire dai 30fps e dal nuovo sensore partially stacked da 33Mpixel. L'abbiamo provata per un breve periodo, ecco come è andata dopo averla messa alle strette.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 20-06-2009, 16:56   #1
doomer
Member
 
Iscritto dal: Dec 2007
Messaggi: 113
[MySQL] cancellare sapendo il numero di riga

Salve, sto programmando in PHP usando una basi dati con mysql...
volevo sapere se esiste un modo in mysql per cancellare una riga di una tabella conoscendo solo il numero di riga da cancellare.
ad esempio:

Codice:
Nome     attributo1 attributo2
pippo     a              a
pluto     b              b
paperino  c              c
se ad esempio volessi cancellare solo la seconda riga ottenendo:
Codice:
Nome     attributo1 attributo2
pippo     a              a
paperino  c              c
è possibile?
doomer è offline   Rispondi citando il messaggio o parte di esso
Old 20-06-2009, 21:55   #2
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
Se non usi una chiave primaria che identifichi in maniera univoca un record ciò che chiedi non ha senso. I record all'interno di una tabella hanno per definizione una collocazione fisica casuale, quindi non esiste una "i-esima" riga.
john_revelator è offline   Rispondi citando il messaggio o parte di esso
Old 20-06-2009, 22:56   #3
doomer
Member
 
Iscritto dal: Dec 2007
Messaggi: 113
hanno una chiave primaria, e vengono visualizzati ordinati sempre secondo quella chiave, quindi sempre nello stesso ordine... per questo penso che la mia domanda non sia insensata
doomer è offline   Rispondi citando il messaggio o parte di esso
Old 20-06-2009, 23:01   #4
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
Nella tabellina che hai postato non vedo alcun id.
Nel caso esista basta che faccia

delete from tabella where id = 2
john_revelator è offline   Rispondi citando il messaggio o parte di esso
Old 20-06-2009, 23:12   #5
doomer
Member
 
Iscritto dal: Dec 2007
Messaggi: 113
la tabellina era solo un esempio
il problema è che ho tante tabelle tutte diverse e con i nomi degli id diversi... e vorrei fare un' interfaccia web standard che vada bene per qualsiasi tabella in modo che un utente possa selezionare un record con una checkbox e premere un pulsante per cancellarlo... e appunto per me sarebbe comodo un modo per cancellare il record avendo il numero della riga, e non contando sugli id visto che come ho detto sono diversi da tabella a tabella
doomer è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2009, 12:43   #6
CwNd
Senior Member
 
L'Avatar di CwNd
 
Iscritto dal: Jun 2007
Città: Milano
Messaggi: 413
Non posso che quotare john_revelator per quanto riguarda il discorso dell'indice posizionale.
I record in una tabella si identificano univocamente con la chiave primaria, e non è assolutamente vero, in termini generali, che vengono ordinati tramite la chiave primaria (vedasi gli indici clustered).

Detto questo, puoi semplicemente assegnare all'attributo value della checkbox il valore della chiave primaria (se non è composta, altrimenti questo giochetto non è così "immediato") e tramite php recuperarlo ed effettuare la query di cancellazione.
CwNd è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2009, 14:24   #7
doomer
Member
 
Iscritto dal: Dec 2007
Messaggi: 113
vabbe ho capito... non si può
doomer è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2009, 00:10   #8
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Quote:
Originariamente inviato da doomer Guarda i messaggi
vabbe ho capito... non si può
Ciao

Ma non è che non si può fare.

il problema è questo:

Se hai tabelle senza una chiave che identifichi in maniera unica ed assoluta la riga contenente i dati, puoi rischiare di cancellare più records alla volta.

Per esempio, se la tabella fosse composta solo da Cognome, Nome:

Codice:
benneth, raoul
rossi, mario
rossi, luigi
rossi mario
Per cancellare un record, normalmente dovresti fare con qualsiasi database:

Codice:
DELETE FROM nome_tabella WHERE 'campo_tabella' = 'valore'
Supponi che tu voglia cancellare uno solo dei 'sig. rossi', dovresti fare:

Codice:
DELETE from nome_tabella WHERE cognome = 'rossi'

//ahiahi..  in questo caso li elimineresti tutti e tre
//ok.. gli do nome e cognome

DELETE from nome_tabella WHERE cognome = 'rossi' AND nome = 'mario'

//ahaha.. ti ho fregato!...

//IL DATABASE Risponde:

//ti sei fregato da solo, c'erano due sig. Rossi Mario, li ho rispediti nel paradiso dei NULL
Scherzi a parte, ecco perchè se non hai un identificativo univoco, quello che chiedi risulta molto complicato da fare.

Se setti una chiave per le tue tabelle, una volta che recuperi i valori a video, oltre a recuperare anche il valore dei vari 'cognome e nome', avrai una variabile che memorizzerà anche la id e, quando tu farai uso della funzione abbinata al tuo check box, potrai dire semplicemente:

Codice:
DELETE FROM nome_tabella WHERE id = 'valore'
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2009, 13:05   #9
doomer
Member
 
Iscritto dal: Dec 2007
Messaggi: 113
no, non hai capito qual'era il problema... il fatto è che io voglio usare la stessa funzione per gestire qualsiasi tabella... ma tabelle che hanno una chiave primaria... il problema era solo che il nome delle chiavi primarie è diverso da tabella a tabella (ad esempio possono essere idc, idg, idp ecc) quindi non posso fare WHERE idc=x perchè questa cosa andrebbe bene solo per la tabella con quella chiave primaria e non per tutte le altre...
comunque ho risolto prendendo tutti i valori della riga, prendendo cosi automaticamente anche la chiave primaria, cioe WHERE attr1=x1 AND attr2=x2 ecc, con gli attr che sono i nomi delle colonne e le x i valori della riga selezionata
doomer è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2009, 14:15   #10
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
Quote:
Originariamente inviato da doomer Guarda i messaggi
no, non hai capito qual'era il problema... il fatto è che io voglio usare la stessa funzione per gestire qualsiasi tabella... ma tabelle che hanno una chiave primaria... il problema era solo che il nome delle chiavi primarie è diverso da tabella a tabella (ad esempio possono essere idc, idg, idp ecc) quindi non posso fare WHERE idc=x perchè questa cosa andrebbe bene solo per la tabella con quella chiave primaria e non per tutte le altre...
comunque ho risolto prendendo tutti i valori della riga, prendendo cosi automaticamente anche la chiave primaria, cioe WHERE attr1=x1 AND attr2=x2 ecc, con gli attr che sono i nomi delle colonne e le x i valori della riga selezionata
La cosa è sicuramente fattibile.

Se scrivi la query

describe nome_tabella

oppure

show columns from nome_tabella

recuperi l'elenco di tutti i campi. Sotto la colonna Key puoi vedere tu stesso che c'è una voce PRI che fa riferimento alla chiave primaria. Una volta fatta la query tramite mysql_fetch_assoc() saresti in grado di recuperare l'elenco dei campi e costruire dinamicamente la query in base al nome della tabella che immagino venga passato via POST.
john_revelator è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando Due mesi di Battlefield 6: dalla campagna al bat...
Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare Antigravity A1: drone futuristico per riprese a ...
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator Sony Alpha 7 V, anteprima e novità della ...
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1 realme GT 8 Pro Dream Edition: prestazioni da fl...
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
X ha disattivato l'account pubblicitario...
Colpo di scena a Hollywood: Paramount pr...
Malesia, giro di vite sul mining illegal...
Meta rivede la roadmap: visore ultralegg...
Addio ricariche continue con le elettric...
Maxi sconto sul robot del futuro: roboro...
I 3 super TV OLED e QLED crollati su Ama...
Tre notebook fuori di testa in sconto: M...
Sconti iPhone su Amazon: oggi ci sono i ...
Google rende disponibile Gemini 3 Deep T...
I 3 super robot Dreame Aqua10 Roller tor...
Tornano in sconto le scope elettriche Ti...
IA nei videogiochi: anche SEGA la utiliz...
Apple in piena tempesta: anche il boss d...
Due GeForce GTX 580 in SLI: l'insospetta...
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: 00:32.


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