Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming
Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming
Questo mouse ultraleggero, con soli 36 grammi di peso, è stato concepito per offrire un'esperienza di gioco di alto livello ai professionisti degli FPS, grazie al polling rate a 8.000 Hz e a un sensore ottico da 33.000 DPI. La recensione esplora ogni dettaglio di questo dispositivo di gioco, dalla sua agilità estrema alle specifiche tecniche che lo pongono un passo avanti
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni
Dal richiamo di Enrico Letta alla necessità di completare il mercato unico entro il 2028 alla visione di Nokia sul ruolo dell’IA e delle reti intelligenti, il Nokia Innovation Day 2025 ha intrecciato geopolitica e tecnologia, mostrando a Vimercate come la ricerca italiana contribuisca alle sfide globali delle telecomunicazioni
Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza
Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza
OPPO Reno14 F 5G si propone come smartphone di fascia media con caratteristiche equilibrate. Il device monta processore Qualcomm Snapdragon 6 Gen 1, display AMOLED da 6,57 pollici a 120Hz, tripla fotocamera posteriore con sensore principale da 50MP e generosa batteria da 6000mAh con ricarica rapida a 45W. Si posiziona come alternativa accessibile nella gamma Reno14, proponendo un design curato e tutto quello che serve per un uso senza troppe preoccupazioni.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 01-04-2016, 15:34   #1
cenarius_88
Member
 
Iscritto dal: Nov 2007
Città: Alcamo
Messaggi: 103
[PHP + MySQLi + HTML] Gestione completa database

Salve a tutti, vorrei realizzare tramite un server locale (XAMPP) impostando opportunamente il contenuto in pagine di HTML + PHP la gestione di una database

Spiego l'idea base
Ho una tabella di persone(id, nome, cognome, data_di_nascita) e una tabella info(id,id_persona,peso,altezza,età) collegate tra di loro tramite persona.id=info.id_personae devo poter

visualizzare in forma tabellare tutte le righe e i campi di persone e persone join info(escluso gli id, magari paginata a blocchi di 30 persone con link <prev;next>) comprese 3 icone relative a "dettagli" "modifica" "cancella" ad ognuna delle quali associo, magari in altre pagine php, la gestione della relativa funzione.

Non mi importa l'aspetto grafico, quanto l'aspetto tecnico implementativo...

Parto dall'idea che il tutto deve essere effettuato tramite query SQL, e spulciando in rete ho visto che si adopera l'accoppiata PHP+MSQLi (conformazione orientata agli oggetti)
Ho sempre provato a fare le query in modo procedurale, e quindi all'arrivo del modo orientato agli oggetti mi trovo "leggermente" disorientato (so cosa è la programmazione ad oggetti)

Dato per assodato che ho una pagina php in cui sono miste righe di HTML e di PHP ed una pagina php solo per contenere le funzioni relative
Nel file delle funzioni ho qualcosa di questo tipo:
Codice:
  $nomehost = "localhost";     
   $nomeuser = "usr";          
   $password = "pswd";
   $nomedb = "database";      

   $conn = new mysqli($nomehost,$nomeuser,$password,$nomedb);

   //visualizzazione di tutti gli utenti
   function utenti($query,$conn){
            $result = $conn->query($query);
            $result->data_seek(0);
            while($row = $result->fetch_assoc()){
              echo 
              '<span class="cella">' . $row['cognome'] . '</span>' .
              '<span class="cella">' . $row['nome'] . '</span>' .
              '<span class="cella">' . date('d-m-Y', strtotime($row['data di nascita']))  . '</span>' .
              '<span class="icon">' . '<a href="#?id='. $row['id'] . '"><img src="images/edit.png" alt="modifica" title="modifica"></a>' . '</span>' .
              '<span class="icon">' . '<a href="#?id='. $row['id'] . '"><img src="images/delete.png" alt="cancella" title="cancella"></a>' . '</span>' .
             '<br>';
             }
    }
che poi includo nel file d base tramite l'apposito tag..

Il dubbio sta nel fatto che, così come l'ho impostato, ho l'idea che appena viene eseguita l'inclusione php nell'HTML viene automaticamente effettuata la connessione al database e viene lasciata aperta (anche perchè non ho implementato la funzione che chiude tutto e non ho ancora gestito eventuali errori) in attesa che venga richiamata la funzione utenti(.....)

Se volessi fare qualcosa di più pulito dovrei fare tipo
Codice:
$nomehost = "localhost";     
   $nomeuser = "usr";          
   $password = "pswd";
   $nomedb = "database";      

   

   //visualizzazione di tutti gli utenti
   function utenti($query){
            //solo quando richiamata avvio la connessione al database)
            $conn = new mysqli($nomehost,$nomeuser,$password,$nomedb);
           //effettuo la query che viene dall'esterno
            $result = $conn->query($query);
            $result->data_seek(0);
            while($row = $result->fetch_assoc()){
              echo 
              '<span class="cella">' . $row['cognome'] . '</span>' .
              '<span class="cella">' . $row['nome'] . '</span>' .
              '<span class="cella">' . date('d-m-Y', strtotime($row['data di nascita']))  . '</span>' .
              '<span class="icon">' . '<a href="#?id='. $row['id'] . '"><img src="images/edit.png" alt="modifica" title="modifica"></a>' . '</span>' .
              '<span class="icon">' . '<a href="#?id='. $row['id'] . '"><img src="images/delete.png" alt="cancella" title="cancella"></a>' . '</span>' .
             '<br>';
             }
    }
??

Scusate se mi sono dilungato e se magari sono stato poco chiaro...
cenarius_88 è offline   Rispondi citando il messaggio o parte di esso
Old 04-04-2016, 10:13   #2
les2
Senior Member
 
L'Avatar di les2
 
Iscritto dal: Mar 2001
Città: MI
Messaggi: 1801
sai che non ho capito cosa chiedi?

secondo me semplicemnete nel modulo dove hai le funzoni crei quelle che ti servono in cui cabli l'sql e gli passi solo i parametri e restituisci l'output.
quando hai l'oggetto output semplicemnte lo cicli e crei l'html.

quindi giochi tutto la sql in modo da avere un oggetto (o array) con le righe che ti servono.

spero di esserti stato di aiuto anche se non ne sono convinto
__________________
italiarec.com forum italiano di registrazione e mixaggio
estilocaballero.es ssdoptimizer.eu cambioeuro.eu doflamingo.com studiolegalesangalli.com stilegentiluomo.it italiarec.com italiarec.it arteincasa.it
les2 è offline   Rispondi citando il messaggio o parte di esso
Old 04-04-2016, 21:51   #3
cenarius_88
Member
 
Iscritto dal: Nov 2007
Città: Alcamo
Messaggi: 103
La mia domanda generalmente era formulata male :X

Quello che chiedevo è questo:
Ho html misto a php in cui mi interfaccio con un database con MySQLi in approccio objected oriented (poichè MySQL in approccio procedurale è deprecato)

So che devo fare un file a parte in php (il tipico config.php) in cui devo inserire tutte le funzioncine (sia per la connessione-disconnessione, per le query, e per l'impaginazione dei risultati delle query), tuttavia non so se devo ogni volta da ogni funzione che prova una query richiamare la funzione connetti, eseguire la query e poi richiamare l'eventuale funzione disconnetti (che, ad oggi, non ho ancora implementato in quanto non ho trovato informazioni a riguardi... l'unica cosa che ho letto è che in pratica una volta finita la query dovrebbe e ripeto dovrebbe chiudere la connessione automaticamente..)
__________________
Notebook: Asus K52J
Smartphone: Huawei P8 Lite
cenarius_88 è offline   Rispondi citando il messaggio o parte di esso
Old 05-04-2016, 08:29   #4
Jones D. Daemon
Senior Member
 
Iscritto dal: Jun 2011
Messaggi: 2814
Quote:
Originariamente inviato da cenarius_88 Guarda i messaggi
La mia domanda generalmente era formulata male :X

Quello che chiedevo è questo:
Ho html misto a php in cui mi interfaccio con un database con MySQLi in approccio objected oriented (poichè MySQL in approccio procedurale è deprecato)

So che devo fare un file a parte in php (il tipico config.php) in cui devo inserire tutte le funzioncine (sia per la connessione-disconnessione, per le query, e per l'impaginazione dei risultati delle query), tuttavia non so se devo ogni volta da ogni funzione che prova una query richiamare la funzione connetti, eseguire la query e poi richiamare l'eventuale funzione disconnetti (che, ad oggi, non ho ancora implementato in quanto non ho trovato informazioni a riguardi... l'unica cosa che ho letto è che in pratica una volta finita la query dovrebbe e ripeto dovrebbe chiudere la connessione automaticamente..)

Per esperienza ti consiglio di usare un qualcosa di già pronto, ti eviti sbattimenti vari nel creare una cosa banale ma che può portare via molto tempo, sopratutto nella gestione degli errori.

http://crud-admin-generator.com/

Quel tool richiede solo ed esclusivamente la connessione al db da configurare nell'apposito file, e da li ti crea in automatico la view dell'interfaccia di admin delle tabelle presenti nel db. Occhio a configurare bene le foreign key in mysql, se le configuri in cascade le cancellazioni effettuate su una tabella si propagheranno in automatico all'altra seguendo la chiave impostata.


Altra opzione potrebbe essere quella di utilizzare un framework già bello che funzionante, come cakephp. Con un framework creare una pagina di gestione tabelle come quella che serve a te è molto facile.
__________________
IntelCore i7 4770s - Asus H97I-PLUS - 2 x 8gb Kingston HyperX Fury - NZXT Manta Black/Red - Cooler Master V700 - 2 x Samsung 850 EVO 250GB Raid0 - WD Caviar RED 2TB - MSI GTX 1070 Gaming X
Jones D. Daemon è offline   Rispondi citando il messaggio o parte di esso
Old 05-04-2016, 10:41   #5
cenarius_88
Member
 
Iscritto dal: Nov 2007
Città: Alcamo
Messaggi: 103
Quote:
Originariamente inviato da Jones D. Daemon Guarda i messaggi
Per esperienza ti consiglio di usare un qualcosa di già pronto, ti eviti sbattimenti vari nel creare una cosa banale ma che può portare via molto tempo, sopratutto nella gestione degli errori.

http://crud-admin-generator.com/

Quel tool richiede solo ed esclusivamente la connessione al db da configurare nell'apposito file, e da li ti crea in automatico la view dell'interfaccia di admin delle tabelle presenti nel db. Occhio a configurare bene le foreign key in mysql, se le configuri in cascade le cancellazioni effettuate su una tabella si propagheranno in automatico all'altra seguendo la chiave impostata.


Altra opzione potrebbe essere quella di utilizzare un framework già bello che funzionante, come cakephp. Con un framework creare una pagina di gestione tabelle come quella che serve a te è molto facile.
Ti ringrazio per il suggerimento... sto provando cakephp ma non so, forse sono io negato per i framework già predefiniti, non riesco nemmeno a far partire la pagina index.php
Codice:
You must enable the intl extension to use CakePHP. in C:\xampp\htdocs\kk\config\bootstrap.php on line 43
Essendo un framework che lavora in php ho pensato di inserirlo nel server locale xampp così può soddisfare le richieste..



Niente... mi sono letto un attimo una semi guida su un sito... ma che roba è? dovrebbe aiutare, e magari lo farà, ma per configurarlo inizialmente ci vogliono infinite conoscenze pregresse (tirate fuori da dove?)

Continuerò per la mia strada
__________________
Notebook: Asus K52J
Smartphone: Huawei P8 Lite

Ultima modifica di cenarius_88 : 05-04-2016 alle 10:55.
cenarius_88 è offline   Rispondi citando il messaggio o parte di esso
Old 05-04-2016, 10:55   #6
Jones D. Daemon
Senior Member
 
Iscritto dal: Jun 2011
Messaggi: 2814
Quote:
Originariamente inviato da cenarius_88 Guarda i messaggi
Ti ringrazio per il suggerimento... sto provando cakephp ma non so, forse sono io negato per i framework già predefiniti, non riesco nemmeno a far partire la pagina index.php
Codice:
You must enable the intl extension to use CakePHP. in C:\xampp\htdocs\kk\config\bootstrap.php on line 43
Essendo un framework che lavora in php ho pensato di inserirlo nel server locale xampp così può soddisfare le richieste..
Devi modificare il file php.ini per fargli caricare quell'estensione:

1 - Apri il pannello di controllo xampp
2 - Clicca su config nella riga di apache
3 - clicca su php.ini
4 - trova questa voce ;extension=php_intl.dll e togli il ; iniziale
5 - salva e riavvia apache

i framework di solito hanno delle dipendenze sulle estensione php che non sono attiva di default. La procedura è sempre questa, devi solo attivare mano mano le estensioni richieste

EDIT:

https://www.codeofaninja.com/2012/04...-tutorial.html

questo fa al caso tuo, è esattamente quello che devi fare. Per iniziare va più che bene
__________________
IntelCore i7 4770s - Asus H97I-PLUS - 2 x 8gb Kingston HyperX Fury - NZXT Manta Black/Red - Cooler Master V700 - 2 x Samsung 850 EVO 250GB Raid0 - WD Caviar RED 2TB - MSI GTX 1070 Gaming X

Ultima modifica di Jones D. Daemon : 05-04-2016 alle 11:01.
Jones D. Daemon è offline   Rispondi citando il messaggio o parte di esso
Old 06-04-2016, 16:11   #7
cenarius_88
Member
 
Iscritto dal: Nov 2007
Città: Alcamo
Messaggi: 103
Grazie, scusami se non ho risposto prima ma non mi ero accorto del tuo ultimo intervento.

Il progetto che mi proponevo di fare l'ho completato già, facendolo tutto per intero senza template

Appena ho del tempo mi leggerò quella guida per carpirne i segreti

Grazie della disponibilità dimostrata
__________________
Notebook: Asus K52J
Smartphone: Huawei P8 Lite
cenarius_88 è offline   Rispondi citando il messaggio o parte di esso
Old 07-04-2016, 11:10   #8
les2
Senior Member
 
L'Avatar di les2
 
Iscritto dal: Mar 2001
Città: MI
Messaggi: 1801
va beh ma se hai tutto e devi fare un porting del driver mysql a mysqli non farti troppi crucci e fai una mera sostituzione, cambia solo leggermente il modo in cui lo chiami e la guida ufficiale ti basta per i dubbi.

se non hai problemi particolari di performance non farti pippe sulle connessioni, continua come hai fatto fin'ora (apri e chiudi o sempre aperte...)
__________________
italiarec.com forum italiano di registrazione e mixaggio
estilocaballero.es ssdoptimizer.eu cambioeuro.eu doflamingo.com studiolegalesangalli.com stilegentiluomo.it italiarec.com italiarec.it arteincasa.it
les2 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming Un fulmine sulla scrivania, Corsair Sabre v2 Pro...
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni Nokia Innovation Day 2025: l’Europa ha bisogno d...
Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza Sottile, leggero e dall'autonomia WOW: OPPO Reno...
Destiny Rising: quando un gioco mobile supera il gioco originale Destiny Rising: quando un gioco mobile supera il...
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo Plaud Note Pro convince per qualità e int...
Adesso ci si può laureare in stor...
Impact.com ridefinisce il performance ma...
Nintendo non considera le mod dannose pe...
Dreame inaugura il suo flagship store a ...
OpenAI e Jony Ive: in arrivo un disposit...
TikTok, secondo Trump l'accordo con Xi &...
HUAWEI, tutte le novità dell'even...
Mercedes GenH2 Truck sulle Alpi: oltre 1...
Shadow Leak: ecco come ChatGPT poteva es...
Google Gemini 2.5 batte quasi tutti gli ...
Battlefield 6: i giocatori console non p...
Iliad rinnova l'offerta mobile: tre pian...
HUAWEI Watch GT 6 ufficiale: design al t...
Reggie Townsend di SAS: l’etica dell’IA ...
Startup Marathon in vista del traguardo:...
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:46.


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