PHP വികസനത്തിനായി MySQL-ൽ DATETIME-നും TIMESTAMP-നും ഇടയിൽ തിരഞ്ഞെടുക്കുന്നു

PHP

MySQL-ൽ തീയതിയും സമയവും ഡാറ്റ തരങ്ങൾ മനസ്സിലാക്കുന്നു

MySQL-ൽ പ്രവർത്തിക്കുമ്പോൾ, തീയതിയും സമയ മൂല്യങ്ങളും സംഭരിക്കുന്നതിന് അനുയോജ്യമായ ഡാറ്റ തരം തിരഞ്ഞെടുക്കുന്നത് നിങ്ങളുടെ ഡാറ്റാബേസിൻ്റെ പ്രകടനത്തെയും പ്രവർത്തനത്തെയും സാരമായി ബാധിക്കും. ഈ ലേഖനം DATETIME, TIMESTAMP ഡാറ്റ തരങ്ങൾ തമ്മിലുള്ള വ്യത്യാസങ്ങൾ പര്യവേക്ഷണം ചെയ്യുകയും ഒരു PHP സെർവർ-സൈഡ് പരിതസ്ഥിതിയിൽ അവയുടെ ഉപയോഗത്തിനുള്ള ശുപാർശകൾ നൽകുകയും ചെയ്യുന്നു.

ഈ വ്യത്യാസങ്ങൾ മനസ്സിലാക്കുന്നത് നിങ്ങളുടെ ഡാറ്റാബേസ് സ്കീമ ഡിസൈനിനായി അറിവുള്ള തീരുമാനങ്ങൾ എടുക്കാൻ നിങ്ങളെ സഹായിക്കും. രണ്ട് ഡാറ്റാ തരങ്ങളുടെയും സവിശേഷതകൾ ഞങ്ങൾ പരിശോധിക്കുകയും അവയുടെ ഗുണങ്ങളും പരിമിതികളും ചർച്ച ചെയ്യുകയും നിങ്ങളുടെ പ്രത്യേക ആവശ്യങ്ങളും ഉപയോഗ സാഹചര്യങ്ങളും അടിസ്ഥാനമാക്കി ശരിയായ ഒന്ന് തിരഞ്ഞെടുക്കുന്നതിനുള്ള പ്രായോഗിക ഉപദേശം നൽകുകയും ചെയ്യും.

കമാൻഡ് വിവരണം
CREATE TABLE നിർദ്ദിഷ്ട നിരകളും നിയന്ത്രണങ്ങളും ഉപയോഗിച്ച് ഡാറ്റാബേസിൽ ഒരു പുതിയ പട്ടിക സൃഷ്ടിക്കുന്നു.
DATETIME സമയ മേഖലയില്ലാതെ തീയതിയും സമയ മൂല്യങ്ങളും സംഭരിക്കുന്നു. ചരിത്രപരമായ ഡാറ്റയ്ക്ക് അനുയോജ്യം.
TIMESTAMP തീയതിയും സമയ മൂല്യങ്ങളും സംഭരിക്കുന്നു, അവയെ സംഭരണത്തിനായി UTC യിലേക്കും വീണ്ടെടുക്കലിനായി പ്രാദേശിക സമയത്തിലേക്കും പരിവർത്തനം ചെയ്യുന്നു.
AUTO_INCREMENT പട്ടികയിൽ ഒരു പുതിയ റെക്കോർഡ് ചേർക്കുമ്പോഴെല്ലാം ഒരു അദ്വിതീയ നമ്പർ സ്വയമേവ സൃഷ്ടിക്കുന്നു.
DEFAULT CURRENT_TIMESTAMP TIMESTAMP ഫീൽഡിൻ്റെ ഡിഫോൾട്ട് മൂല്യം ഒരു പുതിയ റെക്കോർഡ് സൃഷ്ടിക്കുമ്പോൾ നിലവിലെ തീയതിയും സമയവും സജ്ജമാക്കുന്നു.
$conn->query($sql) ഡാറ്റാബേസിനെതിരെ ഒരു ചോദ്യം നിർവ്വഹിക്കുന്നു. ഡാറ്റ ചേർക്കുന്നതിനും വീണ്ടെടുക്കുന്നതിനും ഉപയോഗിക്കുന്നു.
$conn->fetch_assoc() കോളം പേരുകൾ കീകളാകുന്ന ഒരു അസോസിയേറ്റീവ് അറേ ആയി ഒരു ഫല വരി ലഭ്യമാക്കുന്നു.

MySQL തീയതി, സമയ ഫീൽഡുകൾ നടപ്പിലാക്കുന്നു

നൽകിയിരിക്കുന്ന സ്ക്രിപ്റ്റുകൾ എങ്ങനെ ഫലപ്രദമായി ഉപയോഗിക്കാമെന്ന് കാണിക്കുന്നു ഒപ്പം സെർവർ വശത്ത് PHP ഉപയോഗിച്ച് പ്രവർത്തിക്കുമ്പോൾ MySQL-ലെ ഡാറ്റ തരങ്ങൾ. ആദ്യത്തെ സ്ക്രിപ്റ്റ് ഒരു MySQL പട്ടിക സൃഷ്ടിക്കുന്നു , ഇതിൽ രണ്ട് തീയതിയും സമയ ഫീൽഡുകളും ഉൾപ്പെടുന്നു: event_date ഒപ്പം . ദി തരം ഉപയോഗിക്കുന്നു സമയമേഖലാ പരിഗണനകളില്ലാതെ ഒരു ഇവൻ്റിൻ്റെ നിർദ്ദിഷ്ട തീയതിയും സമയവും സംഭരിക്കാൻ, അത് ചരിത്രപരമായ ഡാറ്റയ്ക്ക് അനുയോജ്യമാക്കുന്നു. ദി TIMESTAMP തരം ഉപയോഗിക്കുന്നു ഓരോ റെക്കോർഡും സൃഷ്‌ടിക്കുമ്പോൾ യാന്ത്രികമായി ട്രാക്കുചെയ്യുന്നതിന്, സംഭരണത്തിന് ശേഷം സമയം UTC യിലേക്കും വീണ്ടെടുക്കുമ്പോൾ പ്രാദേശിക സമയത്തിലേക്കും പരിവർത്തനം ചെയ്യുന്നു. സമയ മേഖലകൾ കണക്കാക്കേണ്ട ആപ്ലിക്കേഷനുകൾക്ക് ഈ വ്യത്യാസം നിർണായകമാണ്. രണ്ടാമത്തെ സ്ക്രിപ്റ്റിൽ ഡാറ്റ എങ്ങനെ ചേർക്കാമെന്ന് വ്യക്തമാക്കുന്നു PHP ഉപയോഗിച്ച് പട്ടിക. ഇത് MySQL ഡാറ്റാബേസുമായി ബന്ധിപ്പിക്കുന്നു, ഒരു തയ്യാറാക്കുന്നു പ്രസ്താവന, ഒരു പുതിയ ഇവൻ്റ് റെക്കോർഡ് ചേർക്കാൻ അത് നടപ്പിലാക്കുന്നു. ഡാറ്റാബേസിലേക്കുള്ള കണക്ഷൻ ഉപയോഗിച്ചാണ് സ്ഥാപിച്ചിരിക്കുന്നത് new mysqli() ഫംഗ്‌ഷൻ, കൂടാതെ ചോദ്യം എക്‌സിക്യൂട്ട് ചെയ്യുന്നു രീതി. കണക്ഷൻ പരാജയപ്പെടുകയോ അന്വേഷണത്തിന് ഒരു പ്രശ്നം നേരിടുകയോ ചെയ്താൽ ഫീഡ്ബാക്ക് നൽകുന്നതിനുള്ള പിശക് കൈകാര്യം ചെയ്യലും സ്ക്രിപ്റ്റിൽ ഉൾപ്പെടുന്നു. ഈ PHP സ്ക്രിപ്റ്റ് തീയതിയും സമയ ഡാറ്റയും ശരിയായി ഫോർമാറ്റ് ചെയ്യുകയും ഡാറ്റാബേസിലേക്ക് ചേർത്തിട്ടുണ്ടെന്നും ഉറപ്പാക്കുന്നു.

മൂന്നാമത്തെ സ്ക്രിപ്റ്റ് ഇതിൽ നിന്ന് ഡാറ്റ വീണ്ടെടുക്കുകയും പ്രദർശിപ്പിക്കുകയും ചെയ്യുന്നു മേശ. ഇത് വീണ്ടും ഡാറ്റാബേസിലേക്ക് ബന്ധിപ്പിക്കുന്നു, പ്രവർത്തിക്കുന്നു a എല്ലാ റെക്കോർഡുകളും ലഭ്യമാക്കാൻ അഭ്യർത്ഥിക്കുകയും ഫലങ്ങൾ പ്രോസസ്സ് ചെയ്യുകയും ചെയ്യുന്നു. ദി ഓരോ വരിയും ഒരു അസോസിയേറ്റീവ് അറേ ആയി ലഭ്യമാക്കാൻ ഫംഗ്ഷൻ ഉപയോഗിക്കുന്നു, ഇത് കോളം മൂല്യങ്ങളിലേക്ക് അവയുടെ പേരുകൾ ഉപയോഗിച്ച് എളുപ്പത്തിൽ ആക്സസ് ചെയ്യാൻ അനുവദിക്കുന്നു. സ്ക്രിപ്റ്റ് പിന്നീട് ഫല സെറ്റിലൂടെ ലൂപ്പ് ചെയ്യുന്നു, ഔട്ട്പുട്ട് ചെയ്യുന്നു id, , , ഒപ്പം ഓരോ റെക്കോർഡിനുമുള്ള ഫീൽഡുകൾ. രണ്ടിലും സംഭരിച്ചിരിക്കുന്ന ഡാറ്റ എങ്ങനെ കൈകാര്യം ചെയ്യാമെന്നും പ്രദർശിപ്പിക്കാമെന്നും ഇത് കാണിക്കുന്നു DATETIME ഒപ്പം ഫോർമാറ്റുകൾ, ആപ്ലിക്കേഷൻ സമയവുമായി ബന്ധപ്പെട്ട വിവരങ്ങൾ ശരിയായി വ്യാഖ്യാനിക്കുകയും അവതരിപ്പിക്കുകയും ചെയ്യുന്നുവെന്ന് ഉറപ്പാക്കുന്നു.

MySQL-ൽ DATETIME, TIMESTAMP എന്നിവ ഉപയോഗിക്കുന്നു

PHP, MySQL: ഡാറ്റാബേസ് സ്കീമ ഡിസൈൻ

// 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.

MySQL പട്ടികയിലേക്ക് ഡാറ്റ ചേർക്കുന്നു

PHP, MySQL: ഡാറ്റ ഉൾപ്പെടുത്തൽ സ്ക്രിപ്റ്റ്

//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();
//

ഡാറ്റ വീണ്ടെടുക്കുകയും പ്രദർശിപ്പിക്കുകയും ചെയ്യുന്നു

PHP, MySQL: ഡാറ്റ ലഭ്യമാക്കുകയും പ്രദർശിപ്പിക്കുകയും ചെയ്യുന്നു

//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();
//

MySQL-ൽ DATETIME-നും TIMESTAMP-നും ഇടയിൽ തിരഞ്ഞെടുക്കുന്നു

ഇടയിൽ തീരുമാനിക്കുമ്പോൾ ഒപ്പം MySQL-ലെ ഡാറ്റ തരങ്ങൾ, അവയുടെ തനതായ സവിശേഷതകളും അവ നിങ്ങളുടെ ആപ്ലിക്കേഷൻ്റെ ആവശ്യകതകളുമായി എങ്ങനെ പൊരുത്തപ്പെടുന്നു എന്നതും പരിഗണിക്കേണ്ടത് അത്യാവശ്യമാണ്. ദി ഉപയോക്താവിൻ്റെ ലൊക്കേഷൻ പരിഗണിക്കാതെ തന്നെ മാറാൻ പാടില്ലാത്ത ചരിത്ര രേഖകളോ ഇവൻ്റ് തീയതികളോ പോലെ വ്യത്യസ്ത സമയ മേഖലകളിലുടനീളം സ്ഥിരതയുള്ള തീയതികളും സമയങ്ങളും സംഭരിക്കുന്നതിന് തരം അനുയോജ്യമാണ്. ഈ കാരണം ആണ് DATETIME സമയ മേഖലകൾ കണക്കിലെടുക്കുന്നില്ല; ഇത് നൽകിയ തീയതിയും സമയവും കൃത്യമായി സംഭരിക്കുന്നു, ഇത് ഉപയോഗിക്കാൻ എളുപ്പമുള്ളതാക്കുന്നു, എന്നാൽ ആഗോള സ്ഥിരത ആവശ്യമെങ്കിൽ അത് പ്രശ്‌നമുണ്ടാക്കും.

മറുവശത്ത്, ദി യുടിസിയുമായി ബന്ധപ്പെട്ട സമയ മൂല്യങ്ങൾ സംഭരിക്കുന്നതിനാണ് ടൈപ്പ് രൂപകൽപ്പന ചെയ്‌തിരിക്കുന്നത്, വീണ്ടെടുക്കുമ്പോൾ അവയെ സെർവറിൻ്റെ സമയ മേഖലയിലേക്ക് യാന്ത്രികമായി പരിവർത്തനം ചെയ്യുന്നു. ഇത് ഉണ്ടാക്കുന്നു വ്യത്യസ്ത സമയ മേഖലകളിലുടനീളം സ്ഥിരത ഉറപ്പാക്കുന്നതിനാൽ, റെക്കോർഡ് സൃഷ്‌ടിക്കൽ അല്ലെങ്കിൽ അപ്‌ഡേറ്റ് സമയങ്ങൾ പോലുള്ള മാറ്റങ്ങൾ ട്രാക്കുചെയ്യുന്നതിന് പ്രത്യേകിച്ചും ഉപയോഗപ്രദമാണ്. കൂടെ ജോലി ചെയ്യുമ്പോൾ , ഉപയോഗിക്കുന്നത് TIMESTAMP സമയമേഖലാ വ്യത്യാസങ്ങളുടെ മാനേജ്മെൻ്റ് ലളിതമാക്കാൻ കഴിയും, കൃത്യമായ പ്രാദേശിക സമയം ഉപയോഗിച്ച് ഉപയോക്താക്കളെ അവതരിപ്പിക്കുന്നത് എളുപ്പമാക്കുന്നു. എന്നിരുന്നാലും, താരതമ്യപ്പെടുത്തുമ്പോൾ കൂടുതൽ പരിമിതമായ ശ്രേണി ഉണ്ട് 1970 മുതൽ 2038 വരെയുള്ള തീയതികൾ മാത്രം പിന്തുണയ്ക്കുന്നു, ഇത് ദീർഘകാല ആപ്ലിക്കേഷനുകൾക്കുള്ള പരിഗണനയായിരിക്കാം.

  1. MySQL-ൽ DATETIME-നും TIMESTAMP-നും തമ്മിലുള്ള പ്രധാന വ്യത്യാസം എന്താണ്?
  2. തീയതിയും സമയവും അതേപടി സംഭരിക്കുന്നു ഇത് യുടിസിയിൽ സംഭരിക്കുകയും സെർവറിൻ്റെ സമയ മേഖലയിലേക്ക് പരിവർത്തനം ചെയ്യുകയും ചെയ്യുന്നു.
  3. ഇവൻ്റ് തീയതികൾ റെക്കോർഡ് ചെയ്യുന്നതിന് ഞാൻ ഏത് തരത്തിലുള്ള ഡാറ്റയാണ് ഉപയോഗിക്കേണ്ടത്?
  4. സമയ മേഖലകളിലുടനീളം സ്ഥിരത നിലനിർത്തുന്നതിനാൽ ഇവൻ്റ് തീയതികൾക്ക് അഭികാമ്യമാണ്.
  5. റെക്കോർഡ് സൃഷ്‌ടി സമയം ട്രാക്ക് ചെയ്യുന്നതിന് ഏറ്റവും മികച്ച ഡാറ്റ തരം ഏതാണ്?
  6. സൃഷ്ടിക്കൽ സമയം ട്രാക്കുചെയ്യുന്നതിന് അനുയോജ്യമാണ്, കാരണം അത് നിലവിലെ സമയം സ്വയമേവ ഉപയോഗിക്കുകയും സമയ മേഖലകൾക്കായി ക്രമീകരിക്കുകയും ചെയ്യുന്നു.
  7. TIMESTAMP ഉപയോഗിച്ച് MySQL എങ്ങനെയാണ് ടൈം സോണുകൾ കൈകാര്യം ചെയ്യുന്നത്?
  8. MySQL സ്റ്റോറുകൾ യുടിസിയിലെ മൂല്യങ്ങൾ വീണ്ടെടുക്കുമ്പോൾ നിലവിലെ സമയ മേഖലയിലേക്ക് പരിവർത്തനം ചെയ്യുന്നു.
  9. എനിക്ക് TIMESTAMP ഉപയോഗിച്ച് 1970-ന് മുമ്പുള്ള ഈത്തപ്പഴം സംഭരിക്കാൻ കഴിയുമോ?
  10. ഇല്ല, 1970 നും 2038 നും ഇടയിലുള്ള തീയതികളെ മാത്രമേ പിന്തുണയ്ക്കൂ. ഉപയോഗിക്കുക ഈ പരിധിക്ക് പുറത്തുള്ള തീയതികൾക്ക്.
  11. റെക്കോർഡ് മാറ്റങ്ങളിൽ TIMESTAMP സ്വയമേവ അപ്ഡേറ്റ് ചെയ്യുമോ?
  12. അതെ, ഉപയോഗിച്ച് നിർവചിച്ചാൽ ഒപ്പം , TIMESTAMP യാന്ത്രികമായി അപ്ഡേറ്റ് ചെയ്യുന്നു.
  13. DATETIME ഫീൽഡിൽ ഞാൻ ഒരു അസാധുവായ തീയതി ചേർത്താൽ എന്ത് സംഭവിക്കും?
  14. തീയതി അസാധുവാണെങ്കിൽ, SQL മോഡ് അനുസരിച്ച് MySQL '0000-00-00 00:00:00' ചേർക്കും.
  15. വ്യത്യസ്ത സെർവറുകളിലുടനീളമുള്ള സമയ സംഭരണത്തിൽ എനിക്ക് എങ്ങനെ സ്ഥിരത ഉറപ്പാക്കാനാകും?
  16. ഉപയോഗിക്കുന്നത് എല്ലാ സമയവും UTC ആയി പരിവർത്തനം ചെയ്യുന്നതിനാൽ സമയ സ്ഥിരത ഉറപ്പാക്കുന്നു.
  17. എനിക്ക് DATETIME, TIMESTAMP എന്നിവയ്‌ക്കൊപ്പം ഫംഗ്‌ഷനുകൾ ഉപയോഗിക്കാനാകുമോ?
  18. അതെ, MySQL പോലുള്ള പ്രവർത്തനങ്ങൾ ഒപ്പം രണ്ട് ഡാറ്റ തരങ്ങളിലും പ്രവർത്തിക്കുക.
  19. ഏത് തരത്തിലുള്ള ഡാറ്റയാണ് കൂടുതൽ സംഭരണ ​​കാര്യക്ഷമതയുള്ളത്?
  20. DATETIME-ൻ്റെ 8 ബൈറ്റുകളുമായി താരതമ്യപ്പെടുത്തുമ്പോൾ 4 ബൈറ്റുകൾ ഉപയോഗിച്ച് കൂടുതൽ സംഭരണം കാര്യക്ഷമമാണ്.

MySQL തീയതിയും സമയ തരങ്ങളും സംബന്ധിച്ച അന്തിമ ചിന്തകൾ

ഉപസംഹാരമായി, രണ്ടും ഒപ്പം MySQL ഡാറ്റാബേസ് ഡിസൈനിൽ ഡാറ്റ തരങ്ങൾക്ക് അവയുടെ സ്ഥാനമുണ്ട്. ചരിത്രപരമായ രേഖകൾക്കോ ​​സമയ മേഖലയുടെ സ്ഥിരത നിർണായകമാകുമ്പോഴോ ആണ് തിരഞ്ഞെടുക്കുന്നത് TIMESTAMP യാന്ത്രിക UTC പരിവർത്തനം ഉപയോഗിച്ച് മാറ്റങ്ങൾ ട്രാക്കുചെയ്യുന്നതിന് പ്രയോജനകരമാണ്. കൃത്യവും കാര്യക്ഷമവുമായ തീയതിയും സമയവും കൈകാര്യം ചെയ്യുന്നതിനായി നിങ്ങളുടെ തിരഞ്ഞെടുപ്പ് നിങ്ങളുടെ ആപ്ലിക്കേഷൻ്റെ നിർദ്ദിഷ്ട ആവശ്യങ്ങളുമായി പൊരുത്തപ്പെടണം.