MySQL میں تاریخ اور وقت کے ڈیٹا کی اقسام کو سمجھنا
MySQL کے ساتھ کام کرتے وقت، تاریخ اور وقت کی قدروں کو ذخیرہ کرنے کے لیے مناسب ڈیٹا کی قسم کا انتخاب آپ کے ڈیٹا بیس کی کارکردگی اور فعالیت کو نمایاں طور پر متاثر کر سکتا ہے۔ یہ مضمون DATETIME اور TIMESTAMP ڈیٹا کی اقسام کے درمیان فرق کو تلاش کرتا ہے اور پی ایچ پی کے سرور سائیڈ ماحول میں ان کے استعمال کے لیے سفارشات فراہم کرتا ہے۔
ان امتیازات کو سمجھنے سے آپ کو اپنے ڈیٹا بیس اسکیما ڈیزائن کے لیے باخبر فیصلے کرنے میں مدد ملے گی۔ ہم دونوں قسم کے ڈیٹا کی خصوصیات کا جائزہ لیں گے، ان کے فوائد اور حدود پر تبادلہ خیال کریں گے، اور آپ کی مخصوص ضروریات اور استعمال کے معاملات کی بنیاد پر صحیح کو منتخب کرنے کے لیے عملی مشورہ دیں گے۔
کمانڈ | تفصیل |
---|---|
CREATE TABLE | مخصوص کالموں اور رکاوٹوں کے ساتھ ڈیٹا بیس میں ایک نیا ٹیبل بناتا ہے۔ |
DATETIME | ٹائم زون کے بغیر تاریخ اور وقت کی قدروں کو اسٹور کرتا ہے۔ تاریخی ڈیٹا کے لیے موزوں ہے۔ |
TIMESTAMP | تاریخ اور وقت کی قدروں کو اسٹور کرتا ہے، انہیں اسٹوریج کے لیے UTC میں تبدیل کرتا ہے اور بازیافت کے لیے مقامی وقت میں واپس کرتا ہے۔ |
AUTO_INCREMENT | جب بھی ٹیبل میں نیا ریکارڈ داخل کیا جاتا ہے تو خود بخود ایک منفرد نمبر تیار کرتا ہے۔ |
DEFAULT CURRENT_TIMESTAMP | TIMESTAMP فیلڈ کی ڈیفالٹ قدر کو موجودہ تاریخ اور وقت پر سیٹ کرتا ہے جب نیا ریکارڈ بنایا جاتا ہے۔ |
$conn->query($sql) | ڈیٹا بیس کے خلاف استفسار کرتا ہے۔ ڈیٹا کے اندراج اور بازیافت دونوں کے لیے استعمال کیا جاتا ہے۔ |
$conn->fetch_assoc() | نتیجہ کی قطار کو ایک ایسوسی ایٹیو صف کے طور پر لاتا ہے، جہاں کالم کے نام کلید ہوتے ہیں۔ |
MySQL تاریخ اور وقت کے شعبوں کو نافذ کرنا
فراہم کردہ اسکرپٹس کو مؤثر طریقے سے استعمال کرنے کا طریقہ دکھاتا ہے۔ DATETIME اور TIMESTAMP سرور کی طرف پی ایچ پی کے ساتھ کام کرتے وقت MySQL میں ڈیٹا کی اقسام۔ پہلا اسکرپٹ ایک MySQL ٹیبل بناتا ہے جسے کہا جاتا ہے۔ events، جس میں دو تاریخ اور وقت کی فیلڈز شامل ہیں: event_date اور created_at. دی DATETIME قسم کے لیے استعمال کیا جاتا ہے۔ event_date کسی ایونٹ کی مخصوص تاریخ اور وقت کو ٹائم زون کے تحفظات کے بغیر ذخیرہ کرنے کے لیے، اسے تاریخی ڈیٹا کے لیے موزوں بناتا ہے۔ دی TIMESTAMP قسم کے لیے استعمال کیا جاتا ہے۔ created_at ہر ریکارڈ بننے پر خود بخود ٹریک کرنے کے لیے، اسٹوریج پر وقت کو UTC میں اور بازیافت کے بعد مقامی وقت میں تبدیل کرنا۔ یہ فرق ان ایپلی کیشنز کے لیے بہت اہم ہے جن کو ٹائم زونز کا حساب دینا ہوتا ہے۔ دوسرا اسکرپٹ یہ بتاتا ہے کہ ڈیٹا کو کس طرح داخل کرنا ہے۔ events پی ایچ پی کا استعمال کرتے ہوئے ٹیبل۔ یہ MySQL ڈیٹا بیس سے جڑتا ہے، ایک تیار کرتا ہے۔ INSERT بیان، اور ایک نیا ایونٹ ریکارڈ شامل کرنے کے لیے اس پر عمل درآمد کرتا ہے۔ ڈیٹا بیس سے کنکشن کا استعمال کرتے ہوئے قائم کیا گیا ہے۔ new mysqli() فنکشن، اور استفسار کے ساتھ عمل میں لایا جاتا ہے۔ $conn->query($sql) طریقہ اسکرپٹ میں فیڈ بیک فراہم کرنے کے لیے ایرر ہینڈلنگ بھی شامل ہے اگر کنکشن ناکام ہوجاتا ہے یا استفسار میں کوئی مسئلہ پیش آتا ہے۔ یہ پی ایچ پی اسکرپٹ اس بات کو یقینی بناتا ہے کہ تاریخ اور وقت کا ڈیٹا درست طریقے سے فارمیٹ کیا گیا ہے اور ڈیٹا بیس میں داخل کیا گیا ہے۔
تیسرا اسکرپٹ ڈیٹا کو بازیافت کرتا ہے اور دکھاتا ہے۔ events ٹیبل۔ یہ دوبارہ ڈیٹا بیس سے جڑتا ہے، چلتا ہے۔ SELECT تمام ریکارڈز لانے کے لیے استفسار کریں، اور نتائج پر کارروائی کریں۔ دی $result->fetch_assoc() فنکشن کا استعمال ہر قطار کو ایک ایسوسی ایٹیو ارے کے طور پر لانے کے لیے کیا جاتا ہے، جس سے کالم کی قدروں تک ان کے ناموں تک آسانی سے رسائی کی اجازت ملتی ہے۔ اس کے بعد اسکرپٹ رزلٹ سیٹ سے گزرتا ہے، آؤٹ پٹ کرتا ہے۔ id، event_name، event_date، اور created_at ہر ریکارڈ کے لیے فیلڈز۔ یہ ظاہر کرتا ہے کہ دونوں میں ذخیرہ شدہ ڈیٹا کو کیسے ہینڈل اور ڈسپلے کرنا ہے۔ DATETIME اور TIMESTAMP فارمیٹس، اس بات کو یقینی بناتے ہوئے کہ ایپلیکیشن وقت سے متعلق معلومات کی صحیح ترجمانی اور پیش کرے۔
MySQL میں DATETIME اور TIMESTAMP استعمال کرنا
پی ایچ پی اور ایس کیو ایل: ڈیٹا بیس اسکیما ڈیزائن
// 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
// 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
// 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 کے درمیان انتخاب کرنا
کے درمیان فیصلہ کرتے وقت DATETIME اور TIMESTAMP MySQL میں ڈیٹا کی اقسام، ان کی منفرد خصوصیات پر غور کرنا ضروری ہے اور یہ کہ وہ آپ کی ایپلی کیشن کی ضروریات کے مطابق کیسے ہیں۔ دی DATETIME قسم تاریخوں اور اوقات کو ذخیرہ کرنے کے لیے مثالی ہے جن کا مقصد مختلف ٹائم زونز میں مطابقت رکھنا ہے، جیسے کہ تاریخی ریکارڈز یا ایونٹ کی تاریخیں جنہیں صارف کے مقام سے قطع نظر تبدیل نہیں ہونا چاہیے۔ اس وجہ سے ہے DATETIME ٹائم زونز کو مدنظر نہیں رکھتا؛ یہ صحیح تاریخ اور وقت کو محفوظ کرتا ہے جیسا کہ درج کیا گیا ہے، اسے استعمال کرنے میں سیدھا بناتا ہے لیکن اگر عالمی مستقل مزاجی کی ضرورت ہو تو ممکنہ طور پر پریشانی کا باعث بنتا ہے۔
دوسری طرف، the TIMESTAMP type کو UTC کی نسبت وقت کی قدروں کو ذخیرہ کرنے کے لیے ڈیزائن کیا گیا ہے، بازیافت کے بعد انہیں خود بخود سرور کے ٹائم زون میں تبدیل کر دیتا ہے۔ یہ بناتا ہے TIMESTAMP تبدیلیوں کو ٹریک کرنے کے لیے خاص طور پر مفید ہے، جیسے کہ ریکارڈ بنانے یا اپ ڈیٹ کے اوقات، کیونکہ یہ مختلف ٹائم زونز میں مستقل مزاجی کو یقینی بناتا ہے۔ کے ساتھ کام کرتے وقت PHP، کا استعمال کرتے ہوئے TIMESTAMP ٹائم زون کے فرق کے انتظام کو آسان بنا سکتا ہے، جس سے صارفین کو درست مقامی اوقات کے ساتھ پیش کرنا آسان ہو جاتا ہے۔ البتہ، TIMESTAMP کے مقابلے میں زیادہ محدود رینج ہے۔ DATETIMEصرف 1970 سے 2038 تک کی سپورٹنگ تاریخیں، جو طویل مدتی ایپلی کیشنز کے لیے قابل غور ہوسکتی ہیں۔
MySQL DATETIME اور TIMESTAMP کے بارے میں عام سوالات اور جوابات
- MySQL میں DATETIME اور TIMESTAMP کے درمیان بنیادی فرق کیا ہے؟
- DATETIME تاریخ اور وقت کو جیسا کہ ہے، ذخیرہ کرتا ہے۔ TIMESTAMP اسے UTC میں اسٹور کرتا ہے اور اسے سرور کے ٹائم زون میں تبدیل کرتا ہے۔
- ایونٹ کی تاریخوں کو ریکارڈ کرنے کے لیے مجھے کون سا ڈیٹا استعمال کرنا چاہیے؟
- DATETIME ایونٹ کی تاریخوں کے لیے بہتر ہے کیونکہ یہ ٹائم زونز میں مستقل مزاجی کو برقرار رکھتا ہے۔
- ریکارڈ بنانے کے اوقات کو ٹریک کرنے کے لیے کونسی ڈیٹا ٹائپ بہترین ہے؟
- TIMESTAMP تخلیق کے اوقات کو ٹریک کرنے کے لیے مثالی ہے کیونکہ یہ خود بخود موجودہ وقت کا استعمال کرتا ہے اور ٹائم زون کے لیے ایڈجسٹ ہو جاتا ہے۔
- MySQL ٹائم زونز کو TIMESTAMP کے ساتھ کیسے ہینڈل کرتا ہے؟
- MySQL اسٹورز TIMESTAMP UTC میں اقدار اور بازیافت پر انہیں موجودہ ٹائم زون میں تبدیل کرتا ہے۔
- کیا میں TIMESTAMP کا استعمال کرتے ہوئے 1970 سے پہلے کی تاریخیں محفوظ کر سکتا ہوں؟
- نہیں، TIMESTAMP صرف 1970 اور 2038 کے درمیان کی تاریخوں کو سپورٹ کرتا ہے۔ استعمال کریں۔ DATETIME اس حد سے باہر کی تاریخوں کے لیے۔
- کیا TIMESTAMP ریکارڈ کی تبدیلیوں پر خود بخود اپ ڈیٹ ہوتا ہے؟
- ہاں، اگر اس کے ساتھ تعریف کی جائے۔ DEFAULT CURRENT_TIMESTAMP اور ON UPDATE CURRENT_TIMESTAMP, TIMESTAMP خود بخود اپ ڈیٹ ہو جاتا ہے۔
- اگر میں DATETIME فیلڈ میں غلط تاریخ داخل کروں تو کیا ہوگا؟
- اگر تاریخ غلط ہے تو MySQL '0000-00-00 00:00:00' داخل کرے گا، SQL وضع پر منحصر ہے۔
- میں مختلف سرورز میں ٹائم اسٹوریج میں مستقل مزاجی کو کیسے یقینی بنا سکتا ہوں؟
- استعمال کرنا TIMESTAMP وقت کی مستقل مزاجی کو یقینی بناتا ہے کیونکہ یہ ہر وقت کو UTC میں تبدیل کرتا ہے۔
- کیا میں DATETIME اور TIMESTAMP کے ساتھ فنکشنز استعمال کر سکتا ہوں؟
- جی ہاں، مائی ایس کیو ایل کام کرتا ہے۔ NOW() اور CURRENT_TIMESTAMP دونوں قسم کے ڈیٹا کے ساتھ کام کریں۔
- کونسی ڈیٹا کی قسم زیادہ سٹوریج موثر ہے؟
- TIMESTAMP DATETIME کے 8 بائٹس کے مقابلے میں 4 بائٹس کا استعمال کرتے ہوئے، زیادہ ذخیرہ کرنے والا ہے۔
MySQL تاریخ اور وقت کی اقسام پر حتمی خیالات
آخر میں، دونوں DATETIME اور TIMESTAMP ڈیٹا کی قسمیں MySQL ڈیٹا بیس ڈیزائن میں اپنی جگہ رکھتی ہیں۔ DATETIME تاریخی ریکارڈز کے لیے ترجیح دی جاتی ہے یا جب ٹائم زون کی مستقل مزاجی اہم ہوتی ہے، جبکہ TIMESTAMP خودکار UTC تبدیلی کے ساتھ تبدیلیوں کو ٹریک کرنے کے لیے فائدہ مند ہے۔ درست اور موثر تاریخ اور وقت کی ہینڈلنگ کو یقینی بنانے کے لیے آپ کی پسند کو آپ کی درخواست کی مخصوص ضروریات کے مطابق ہونا چاہیے۔