Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy?
Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy?
Google Pixel 10 è uno smartphone che unisce una fotocamera molto più versatile rispetto al passato grazie allo zoom ottico 5x, il supporto magnetico Pixelsnap e il nuovo chip Tensor G5. Il dispositivo porta Android 16 e funzionalità AI avanzate come Camera Coach, mantenendo il design caratteristico della serie Pixel con miglioramenti nelle prestazioni e nell'autonomia. In Italia, però, mancano diverse feature peculiari basate sull'AI.
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
L'abbonamento Ultimate di GeForce NOW ora comprende la nuova architettura Blackwell RTX con GPU RTX 5080 che garantisce prestazioni tre volte superiori alla precedente generazione. Non si tratta solo di velocità, ma di un'esperienza di gioco migliorata con nuove tecnologie di streaming e un catalogo giochi raddoppiato grazie alla funzione Install-to-Play
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Deebot X11 Omnicyclone implementa tutte le ultime tecnologie Ecovacs per l'aspirazione dei pavimenti di casa e il loro lavaggio, con una novità: nella base di ricarica non c'è più il sacchetto di raccolta dello sporco, sostituito da un aspirapolvere ciclonico che accumula tutto in un contenitore rigido
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


Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy? Google Pixel 10 è compatto e ha uno zoom ...
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre Prova GeForce NOW upgrade Blackwell: il cloud ga...
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
Addio treni e aerei? Per Hyperloop un te...
Microsoft porta una comoda novità...
Le azioni Gemini balzano oltre il 30% al...
TSMC diventa produttore di... miele! Dal...
Windows 11 24H2, rimosso un vecchio bloc...
Autunno su AliExpress: sconti folli fino...
È ancora dominio Apple: iPhone 16...
Dogecoin diventa azionista di maggioranz...
xAI, la startup di Elon Musk, si ridimen...
NVIDIA nei guai in Cina: accusata di vio...
Ducati presenta la moto elettrica con ba...
Pikachu Illustrator, la carta Poké...
Mini PC da urlo: prestazioni da desktop ...
Windows 10, scatta il conto alla rovesci...
Errore 1603: AMD spiega come risolvere i...
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: 11:35.


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