Valitseminen DATETIME ja TIMESTAMP välillä MySQL:ssä PHP-kehitystä varten

PHP

Päivämäärä- ja aikatietotyyppien ymmärtäminen MySQL:ssä

Kun työskentelet MySQL:n kanssa, oikean tietotyypin valitseminen päivämäärän ja kellonajan arvojen tallentamiseen voi vaikuttaa merkittävästi tietokantasi suorituskykyyn ja toimivuuteen. Tässä artikkelissa tarkastellaan DATETIME- ja TIMESTAMP-tietotyyppien välisiä eroja ja annetaan suosituksia niiden käyttöön PHP-palvelinpuolen ympäristössä.

Näiden erojen ymmärtäminen auttaa sinua tekemään tietokantaskeeman suunnitteluun perustuvia päätöksiä. Tutkimme molempien tietotyyppien ominaisuuksia, keskustelemme niiden eduista ja rajoituksista sekä tarjoamme käytännön neuvoja oikean tiedon valitsemiseen erityistarpeidesi ja käyttötapaustesi perusteella.

Komento Kuvaus
CREATE TABLE Luo tietokantaan uuden taulukon määritetyillä sarakkeilla ja rajoituksilla.
DATETIME Tallentaa päivämäärän ja kellonajan arvot ilman aikavyöhykettä. Sopii historiallisille tiedoille.
TIMESTAMP Tallentaa päivämäärän ja kellonajan arvot, muuntaen ne UTC:ksi tallennusta varten ja takaisin paikalliseen aikaan noutamista varten.
AUTO_INCREMENT Luo yksilöllisen numeron automaattisesti aina, kun taulukkoon lisätään uusi tietue.
DEFAULT CURRENT_TIMESTAMP Asettaa AIKALEIMA-kentän oletusarvoksi nykyisen päivämäärän ja kellonajan, kun uusi tietue luodaan.
$conn->query($sql) Suorittaa kyselyn tietokannasta. Käytetään sekä tietojen syöttämiseen että hakemiseen.
$conn->fetch_assoc() Hakee tulosrivin assosiatiivisena taulukkona, jossa sarakkeiden nimet ovat avaimia.

MySQL:n päivämäärä- ja aikakenttien käyttöönotto

Toimitetut skriptit osoittavat, kuinka niitä käytetään tehokkaasti ja tietotyypit MySQL:ssä, kun työskentelet PHP:n kanssa palvelinpuolella. Ensimmäinen komentosarja luo MySQL-taulukon nimeltä , joka sisältää kaksi päivämäärä- ja aikakenttää: event_date ja . The tyyppiä käytetään tallentaa tapahtuman tietyn päivämäärän ja kellonajan ilman aikavyöhykenäkökohtia, mikä tekee siitä sopivan historiallisille tiedoille. The TIMESTAMP tyyppiä käytetään automaattisesti seuraamaan, milloin jokainen tietue on luotu, muuntaen ajan UTC:ksi tallennuksen yhteydessä ja takaisin paikalliseen aikaan noudettaessa. Tämä ero on ratkaisevan tärkeä sovelluksille, joiden on otettava huomioon aikavyöhykkeet. Toinen komentosarja havainnollistaa, kuinka tietoja lisätään tiedostoon taulukko PHP:llä. Se muodostaa yhteyden MySQL-tietokantaan, valmistelee lauseke ja suorittaa sen lisätäkseen uuden tapahtumatietueen. Yhteys tietokantaan muodostetaan käyttämällä new mysqli() funktio, ja kysely suoritetaan menetelmä. Skripti sisältää myös virheenkäsittelyn palautteen antamiseksi, jos yhteys epäonnistuu tai kyselyssä ilmenee ongelma. Tämä PHP-skripti varmistaa, että päivämäärä- ja aikatiedot on muotoiltu oikein ja lisätty tietokantaan.

Kolmas komentosarja hakee ja näyttää tiedot tiedostosta pöytä. Se muodostaa jälleen yhteyden tietokantaan, suorittaa a kysely hakeakseen kaikki tietueet ja käsittelee tulokset. The -toimintoa käytetään jokaisen rivin hakemiseen assosiatiivisena taulukkona, mikä mahdollistaa helpon pääsyn sarakkeiden arvoihin niiden nimien perusteella. Komentosarja käy sitten läpi tulosjoukon ja tulostaa id, , , ja kentät jokaiselle tietueelle. Tämä osoittaa, kuinka käsitellä ja näyttää molempiin tallennettuja tietoja DATETIME ja muodoissa varmistaen, että sovellus tulkitsee ja esittää oikein ajankohtaista tietoa.

DATETIME ja TIMESTAMP käyttö MySQL:ssä

PHP ja MySQL: Tietokantakaavion suunnittelu

// Backend: Creating a MySQL Table with DATETIME and TIMESTAMP fields
CREATE TABLE events (
    id INT AUTO_INCREMENT PRIMARY KEY,
    event_name VARCHAR(100) NOT ,
    event_date DATETIME NOT ,
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
// Explanation:
// 'event_date' uses DATETIME to store the date and time of the event.
// 'created_at' uses TIMESTAMP to automatically track the record creation time.

Tietojen lisääminen MySQL-taulukkoon

PHP ja MySQL: Data Insertion Script

//php
// Backend: PHP Script to Insert Data into the MySQL Table
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "database_name";
$conn = new mysqli($servername, $username, $password, $dbname);
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
}
$event_name = "Sample Event";
$event_date = "2024-07-10 12:00:00";
$sql = "INSERT INTO events (event_name, event_date)
VALUES ('$event_name', '$event_date')";
if ($conn->query($sql) === TRUE) {
    echo "New record created successfully";
} else {
    echo "Error: " . $sql . "<br>" . $conn->error;
}
$conn->close();
//

Tietojen haku ja näyttäminen

PHP ja MySQL: tietojen hakeminen ja näyttäminen

//php
// Backend: PHP Script to Retrieve and Display Data from MySQL Table
$conn = new mysqli($servername, $username, $password, $dbname);
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
}
$sql = "SELECT id, event_name, event_date, created_at FROM events";
$result = $conn->query($sql);
if ($result->num_rows > 0) {
    while($row = $result->fetch_assoc()) {
        echo "id: " . $row["id"]. " - Name: " . $row["event_name"].
             " - Event Date: " . $row["event_date"].
             " - Created At: " . $row["created_at"]. "<br>";
    }
} else {
    echo "0 results";
}
$conn->close();
//

Valitse MySQL:ssä DATETIME ja TIMESTAMP

Kun päättää välillä ja Tietotyypit MySQL:ssä, on tärkeää ottaa huomioon niiden ainutlaatuiset ominaisuudet ja kuinka ne vastaavat sovelluksesi vaatimuksia. The tyyppi sopii mainiosti päivämäärien ja kellonaikojen tallentamiseen, joiden on tarkoitus olla johdonmukaisia ​​eri aikavyöhykkeillä, kuten historialliset tietueet tai tapahtumapäivämäärät, joiden ei pitäisi muuttua käyttäjän sijainnista riippumatta. Tämä johtuu siitä, että DATETIME ei ota aikavyöhykkeitä huomioon; se tallentaa tarkan päivämäärän ja kellonajan sellaisena kuin se on syötetty, mikä tekee siitä yksinkertaisen käyttää, mutta voi olla ongelmallista, jos tarvitaan globaalia johdonmukaisuutta.

Toisaalta, tyyppi on suunniteltu tallentamaan aika-arvot suhteessa UTC:hen ja muuttamaan ne automaattisesti palvelimen aikavyöhykkeeksi noudettaessa. Tämä tekee erityisen hyödyllinen muutosten, kuten tietueiden luonti- tai päivitysaikojen, seurantaan, koska se varmistaa johdonmukaisuuden eri aikavyöhykkeillä. Kun työskentelet , käyttämällä TIMESTAMP voi yksinkertaistaa aikavyöhykeerojen hallintaa, mikä helpottaa tarkan paikallisen ajan esittämistä käyttäjille. Kuitenkin, on rajoitetumpi alue verrattuna , tukee vain vuosia 1970–2038, mikä saattaa olla huomioitava pitkäaikaisissa sovelluksissa.

  1. Mikä on tärkein ero DATETIME ja TIMESTAMP välillä MySQL:ssä?
  2. tallentaa päivämäärän ja kellonajan sellaisenaan, while tallentaa sen UTC:ssä ja muuntaa sen palvelimen aikavyöhykkeeksi.
  3. Mitä tietotyyppiä minun tulee käyttää tapahtumapäivien tallentamiseen?
  4. on parempi tapahtumapäiville, koska se säilyttää yhdenmukaisuuden aikavyöhykkeiden välillä.
  5. Mikä tietotyyppi on paras tietueiden luomisaikojen seurantaan?
  6. on ihanteellinen luomisaikojen seurantaan, koska se käyttää automaattisesti nykyistä aikaa ja mukautuu aikavyöhykkeisiin.
  7. Kuinka MySQL käsittelee aikavyöhykkeitä TIMESTAMP:n kanssa?
  8. MySQL-kaupat arvot UTC-muodossa ja muuntaa ne nykyiselle aikavyöhykkeelle noudettaessa.
  9. Voinko tallentaa päivämäärät ennen vuotta 1970 käyttämällä TIMESTAMPia?
  10. Ei, tukee vain vuosia 1970–2038. Käytä tämän alueen ulkopuolisille päivämäärille.
  11. Päivittyykö TIMESTAMP automaattisesti tietueiden muutosten yhteydessä?
  12. Kyllä, jos määritetään ja , TIMESTAMP päivittyy automaattisesti.
  13. Mitä tapahtuu, jos lisään virheellisen päivämäärän DATETIME-kenttään?
  14. MySQL lisää 0000-00-00 00:00:00, jos päivämäärä on virheellinen, riippuen SQL-tilasta.
  15. Kuinka voin varmistaa ajantasaisuuden yhdenmukaisuuden eri palvelimilla?
  16. Käyttämällä varmistaa ajan johdonmukaisuuden, koska se muuntaa kaikki ajat UTC:ksi.
  17. Voinko käyttää toimintoja DATETIME ja TIMESTAMP kanssa?
  18. Kyllä, MySQL toimii kuten ja toimii molempien tietotyyppien kanssa.
  19. Mikä tietotyyppi on tehokkaampi tallennus?
  20. on tallennustehokkaampi, sillä se käyttää 4 tavua verrattuna DATETIMEn 8 tavuun.

Viimeiset ajatukset MySQL:n päivämäärä- ja aikatyypeistä

Lopuksi molemmat ja tietotyypeillä on paikkansa MySQL-tietokannan suunnittelussa. on parempi historiallisille tietueille tai kun aikavyöhykkeen yhdenmukaisuus on ratkaisevan tärkeää TIMESTAMP on edullinen muutosten seurantaan automaattisella UTC-muunnoksella. Valintasi tulee vastata sovelluksesi erityistarpeita varmistaaksesi tarkan ja tehokkaan päivämäärän ja kellonajan käsittelyn.