Torna indietro   Hardware Upgrade Forum > Software > Programmazione

TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
La tecnologia SQD-Mini LED di TCL arriva sul taglio da 65 pollici con la serie C8L: 2040 zone, pannello WHVA 2.0 e un picco che alle rilevazioni delle sonde tocca i 4400 nit nel profilo Filmmaker e un HDR quasi perfetto
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
Wireless 2.4 GHz, Bluetooth 5.4, cancellazione attiva del rumore, design pieghevole e un'autonomia che mette in imbarazzo prodotti che costano il doppio. Le Maestro 500 non eccellono in nulla, ma offrono tutto. E a questo prezzo è difficile chiedere di più
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
Dopo anni di attesa e una lunga fase di sviluppo, Noctua entra nel mercato dei dissipatori a liquido AIO con la nuova serie NL-LC1. Forte dell'esperienza maturata nel raffreddamento ad aria, l'azienda austriaca promette di portare la propria filosofia fatta di qualità costruttiva, attenzione ai dettagli e silenziosità anche in questo segmento. Abbiamo provato il nuovo sistema per scoprire se riesce a distinguersi in un mercato ormai molto competitivo.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 25-05-2011, 15:39   #1
espanico
Senior Member
 
L'Avatar di espanico
 
Iscritto dal: May 2007
Messaggi: 4305
[php+mysql]Inserimento date...

Salve, ho un piccolo script dove mediante un form htm, inserisco dei dati in un db mysql, ora vorrei che quando effettuo la query di inserimento posso inserire e quindi registrare anche la data...e poi successivamente visualizzarla...Come potrei procedere?
__________________
Feedback Mercatino
espanico è offline   Rispondi citando il messaggio o parte di esso
Old 25-05-2011, 16:55   #2
demos88
Senior Member
 
Iscritto dal: Nov 2004
Città: Padova
Messaggi: 2342
Beh hai l'imbarazzo della scelta:
- Memorizzi il timestamp unix come attributo long nel database. Da php la funzione che ritorna il timestamp è time() (hai informazioni anche sull'ora)
- Memorizzi la data in un formato "leggibile", usando attributi DATE (AAAA-MM-GG) oppure DATETIME (AAAA-MM-GG OO:MM:SS) e li puoi ricavare sia da mysql con la funzione NOW() o da php convertendo il timestamp nel formato desiderato.

Poi puoi sbizzarrirti come vuoi per esempio registrando le date come stringhe in un formato che decidi te via php o altro ancora.
In realtà sotto mysql la gestione delle date e del tempo è così varia che spesso si fa un po' di confusione. Io per abitudine preferisco usare il timestamp unix, lo trovo più semplice da usare per i confronti e mediante php lo puoi trasformare in stringa nel formato che preferisci.
__________________
CPU Ryzen 5900X @ 4,7Ghz + Thermalright Phantom Spirit 120 SE / MB Asus X470-F Gaming / RAM 2x16GB DDR4 Corsair 3600 CL16 / VGA Sapphire RX 7900 XT Nitro+ / SSD Crucial T500 1TB + Samsung 970 Pro 512GB + Sandisk 960GB Ultra II / PSU FSP Hydro G PRO 1000W / Headset Kingston HyperX Flight
demos88 è offline   Rispondi citando il messaggio o parte di esso
Old 25-05-2011, 17:10   #3
espanico
Senior Member
 
L'Avatar di espanico
 
Iscritto dal: May 2007
Messaggi: 4305
Infatti può sembra un argomento semplice, invece... adesso faccio qualche prova con timestamp e a limite posto il codice. Un altra cosa siccome lo script/sito che sto realizzando prevede la modifica più aggiunta di dati successivamente al primo inserimento....quindi io vorrei:

Che venga registrata la data del primo inserimento, fin qui dovrebbe essere semplice, mi creo un campo timestamp nel db che vado a popolare con la query di inserimento giusto? poi ho la pagina di aggiornamento dove ci sono 5 campi che potrebbero essere aggiornato oppure no successivamente e vorrei che per ogni campo ci sia la data di modifica, come potrei fare non so se mi sono spiegato bene....
__________________
Feedback Mercatino
espanico è offline   Rispondi citando il messaggio o parte di esso
Old 25-05-2011, 19:34   #4
demos88
Senior Member
 
Iscritto dal: Nov 2004
Città: Padova
Messaggi: 2342
Se ho capito bene tu devi inserire in una tabella dei dati i quali poi possono essere modificati e devi tenere traccia delle modifiche (della data almeno).
Io userei due tabelle: la prima tabella contiene i dati veri e propri aggiornati, nell'altra invece registri le date delle modifiche.
La prima tabella potrebbe essere del tipo:
DATI (id_dato, attributo_1, attributo_2, attributo_3, data_primo_inserimento)
la seconda tabella protrebbe essere:
MODIFICHE (id_modifica, id_dato, attributo_modificato, data_modifica)

L'uso della tabella DATI è logico: quando inserisci un nuovo insieme di dati, crei un nuovo record che avrà un id_dato univoco (puoi farlo autoincrement) che sarà anche la chiave primaria, gli attributi di interesse e la data di primo inserimento.
La tabella MODIFICHE contiene un id_modifca anche questo autoincrement e primary key, una chiave esterna id_dato che riporta l'id del dato modificato, un valore che indica quale attributo è stato modificato e la data di modifica.
Il valore "attributo_identificato" devi decidere te come usarlo. Se per esempio tratti dati anagrafici, potresti dire che "attributo_modificato" assume valori da 1 a 3 dove 1=nome, 2=cognome, 3=C.F...
Potresti anche usare una terza tabella dove associ i numeri agli attributi, ma non è necessario.
In questo caso, se modifichi più attributi alla volta dovrai fare tante query di inserimento quanti sono gli attributi modificati.
__________________
CPU Ryzen 5900X @ 4,7Ghz + Thermalright Phantom Spirit 120 SE / MB Asus X470-F Gaming / RAM 2x16GB DDR4 Corsair 3600 CL16 / VGA Sapphire RX 7900 XT Nitro+ / SSD Crucial T500 1TB + Samsung 970 Pro 512GB + Sandisk 960GB Ultra II / PSU FSP Hydro G PRO 1000W / Headset Kingston HyperX Flight

Ultima modifica di demos88 : 25-05-2011 alle 19:37.
demos88 è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2011, 19:18   #5
espanico
Senior Member
 
L'Avatar di espanico
 
Iscritto dal: May 2007
Messaggi: 4305
Ciao ho fatto qualche prova e non sono riuscito a risolvere, in pratica, non ho capito come fare, ecco un esempio questi sono i campi che possono vengono aggiornati singolarmente e in giorni diversi quindi la data deve essere indipendente...

Campo 1 = xxxxxx Data campo 1 = dd/MM/yyyy
Campo 2 = yyyyy Data campo 1 = dd/MM/yyyy
Campo 3 = zzzzzz Data campo 1 = dd/MM/yyyy

Io per aggiornare i dati nei campi utilizzo questa query:

Codice PHP:
$sql "UPDATE acconti SET acc_1='$_GET[acc_1]', acc_2='$_GET[acc_2]', acc_3='$_GET[acc_3]',  data_mod=sysdate() WHERE id='$_GET[id]'"
Nel database ho creato un campo data_mod, ma in questo modo qualsiasi valori vado ad aggiornare, avrà sempre l'ultima data, come faccio a sdoppiare il tutto, ne senso che vado a creare x campi quando valori ho da modificare in modo che se modifico solo il valore del campo 2 la data viene aggiornata solo per quel campo. Non so se mi sono spiegato bene....
__________________
Feedback Mercatino
espanico è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2011, 22:43   #6
demos88
Senior Member
 
Iscritto dal: Nov 2004
Città: Padova
Messaggi: 2342
Quello a cui avevo pensato era qualcosa del genere:
creo le due tabelle che mi servono
Codice:
CREATE TABLE `db`.`accounts` (
`account_id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
`nome` VARCHAR( 16 ) NOT NULL ,
`cognome` VARCHAR( 16 ) NOT NULL ,
`cf` VARCHAR( 16 ) NOT NULL ,
`data_creazione` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP
) ENGINE = InnoDB;

CREATE TABLE `db`.`modifiche` (
`id_modifica` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
`account` INT NOT NULL ,
`dato_modificato` INT NOT NULL ,
`data_modifica` INT NOT NULL ,
INDEX ( `account` )
) ENGINE = InnoDB;

ALTER TABLE `modifiche` ADD FOREIGN KEY ( `account` ) REFERENCES `db`.`accounts` (
`account_id`
) ON DELETE CASCADE ON UPDATE CASCADE ;
L'inserimento di un nuovo account avviene semplicemente così:
Codice:
INSERT INTO `db`.`accounts` 
VALUES (
NULL , 'Paolo', 'Rossi', 'PLARSS',
CURRENT_TIMESTAMP
);
La modifica di un dato deve essere in parte gestita da php.
Ipotizzo che tu abbia delle caselle di testo da riempire con i nuovi dati (nome, cognome, cf); se all'atto della conferma una casella di testo è vuota oppure corrisponde al contenuto già presente nel DB, allora consideri il dato come non da modificare.
Nello script che riceve i dati (presumiamo via GET) dovrai fare i vari controlli per verificare quali siano i dati da modificare.
Ipotizziamo che tu abbia ricevuto nome e cf nuovi (l'esempio è infelice perchè se cambi il nome è ovvio che cambi anche il cf, ma tralasciamo...).
Nello script php ti ritrovi $_GET['nome'] e $_GET['cf'] non nulli e diversi da quelli nel db (devi aver prima fatto un select ricercando l'id_account dell'account da modificare).
Per modificare i 2 dati, userai in tutto 3 query:
2 per registrare le modifiche:
Codice:
$sql="INSERT INTO `db`.`modifiche`
VALUES (NULL , '". $id_account ."', '1', CURRENT_TIMESTAMP);"

$sql="INSERT INTO `db`.`modifiche`
VALUES (NULL , '". $id_account ."', '3', CURRENT_TIMESTAMP);"
La differenza fra le due query sta nel 3° valore di inserimento che nel primo caso è 1 (indica che la modifica è apportata al nome), nel secondo è 3 (apportata al codice fiscale). Se avessi cambiato il cognome, avrei scritto 2.
Ovviamente $id_account è l'id dell'account che modifichi e devi saperlo.

Poi modifichi i dati veri e propri con una query di UPDATE:
Codice:
$sql="UPDATE `db`.`accounts` SET `nome` = '". $_GET['nome'] ."',
`cf` = '". $_GET['cf'] ."' WHERE `accounts`.`account_id` =". $id_account . ";";
Una cosa del genere...
Al posto dei numeri, per indicare l'attributo modificato puoi usare delle stringe tipo: "n", "c", "cf". Però il confronto fra numeri è in generale più veloce...
__________________
CPU Ryzen 5900X @ 4,7Ghz + Thermalright Phantom Spirit 120 SE / MB Asus X470-F Gaming / RAM 2x16GB DDR4 Corsair 3600 CL16 / VGA Sapphire RX 7900 XT Nitro+ / SSD Crucial T500 1TB + Samsung 970 Pro 512GB + Sandisk 960GB Ultra II / PSU FSP Hydro G PRO 1000W / Headset Kingston HyperX Flight
demos88 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati TCL 65C8L, la recensione del SQD-Mini LED da 440...
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con ...
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming Gigabyte MO32U24 OLED: il 4K a 240Hz su un panne...
SteamOS 3.8 esce dalla beta: supporto pr...
HDMI 2.2 si avvicina: i primi dispositiv...
GTA 6 è sempre più vicino:...
Prima mossa climatica di Anthropic: entr...
Ho scritto un programma da zero con Kimi...
Thermal Grizzly DeltaMate CPU Block: un ...
Il supercomputer più potente al m...
VSCO lancia Studio Pro su iOS: batch edi...
GPT-NL, il modello linguistico olandese ...
Apple Watch SE 3 crolla a 199€: il prezz...
'Non c'è spazio per console econo...
AutoUncle fotografa il mercato dell'usat...
Robase, il malware che ruba interi gioch...
DeepSeek invece di OpenAI in Copilot Cow...
Matter 1.6 rivoluziona la smart home: co...
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: 18:52.


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