- 1 ১. লক্ষ্য শ্রোতা এবং আপনি যা শিখবেন
- 2 ২. LocalDateTime কী? মৌলিক বিষয় এবং অন্যান্য ক্লাসগুলির থেকে পার্থক্য
- 3 ৩. LocalDateTime ইনস্ট্যান্স কীভাবে তৈরি করবেন (কোড উদাহরণ সহ)
- 4 4. LocalDateTime ফরম্যাটিং এবং স্ট্রিং-এ রূপান্তর
- 5 5. তারিখ ও সময় যোগ, বিয়োগ এবং তুলনা (প্র্যাকটিসে সাধারণ)
- 6 6. LocalDateTime-কে অন্যান্য ক্লাস ও ডাটাবেস টাইপে রূপান্তর করা
- 7 7. Practical Use Cases and Quick Reference by Scenario
- 8 8. সাধারণ ত্রুটি, সমস্যার সমাধান, এবং সমাধান
- 8.1 প্রশ্ন ১. DateTimeParseException ঘটেছে
- 8.2 প্রশ্ন ২. NullPointerException থেকে সতর্ক থাকুন
- 8.3 প্রশ্ন ৩. ভুল টাইম জোন হ্যান্ডলিং
- 8.4 প্রশ্ন ৪. ডাটাবেসের সাথে ইন্টিগ্রেট করার সময় তারিখ-সময় মান পরিবর্তিত হয়
- 8.5 প্রশ্ন ৫. নির্ভুলতার ক্ষতি (মিলিসেকেন্ড / ন্যানোসেকেন্ড)
- 8.6 প্রশ্ন ৬. লিগেসি API (Date, Calendar) থেকে রূপান্তর করার সময় ত্রুটি
- 8.7 প্রায়োগিক ডেভেলপমেন্ট টিপস
- 9 9. প্রায়শই জিজ্ঞাসিত প্রশ্নাবলী (FAQ)
- 9.1 Q1. LocalDateTime কি টাইম জোন হ্যান্ডল করতে পারে?
- 9.2 Q2. Date / Calendar থেকে LocalDateTime-এ মাইগ্রেট করার সবচেয়ে নিরাপদ উপায় কী?
- 9.3 Q3. আউটপুটে কখনও কখনও “T” কেন থাকে?
- 9.4 Q4. ডেটাবেসে মান সংরক্ষণ করার সময় কী বিষয়ে সতর্ক থাকা উচিত?
- 9.5 Q5. LocalDateTime কতটা প্রিসিশন সমর্থন করে?
- 9.6 Q6. LocalDateTime কি ডেলাইট সেভিং টাইম (DST) দ্বারা প্রভাবিত হয়?
- 9.7 Q7. যদি শুধুমাত্র তারিখ বা সময় দরকার হয়, আমি কী ব্যবহার করব?
- 9.8 Q8. এক্সসেপশন কীভাবে হ্যান্ডল করা উচিত?
- 10 10. সারাংশ এবং রেফারেন্স লিঙ্ক
১. লক্ষ্য শ্রোতা এবং আপনি যা শিখবেন
জাভায় তারিখ এবং সময়ের সাথে কাজ করার সময় কখনো LocalDateTime ক্লাসটি কীভাবে ব্যবহার করবেন তা নিয়ে কষ্ট পেয়েছেন? এই নিবন্ধটি জাভা শিক্ষানবিস থেকে এন্টারপ্রাইজ সিস্টেমগুলি সক্রিয়ভাবে বিকশিত করা ইঞ্জিনিয়ারদের জন্য ডিজাইন করা হয়েছে, এবং এটি LocalDateTime-এর মৌলিক বিষয় থেকে শুরু করে বাস্তব জীবনের ব্যবহার পর্যন্ত সবকিছু যত্নের সাথে ব্যাখ্যা করে।
এই নিবন্ধ থেকে আপনি যা লাভ করবেন
- LocalDateTime-এর মৌলিক কাঠামো এবং বৈশিষ্ট্যগুলি বুঝুন
- তারিখ এবং সময়ের উপর অ্যারিথমেটিক করা, ফরম্যাট করা, রূপান্তর করা এবং তৈরি করার উপায় কংক্রিট উদাহরণের মাধ্যমে শিখুন
- LocalDateTime এবং Date এবং Calendar-এর মতো লিগ্যাসি API-গুলির মধ্যে পার্থক্য বুঝুন, এবং প্রত্যেকটির কখন ব্যবহার করবেন
- ডাটাবেস ইন্টিগ্রেশনের মতো সাধারণ ব্যবহারের ক্ষেত্র এবং ঘন ঘন দেখা যাওয়া ত্রুটিগুলি হ্যান্ডেল করার উপায় শিখুন
- উন্নয়নে সাধারণ ফাঁদগুলি এড়িয়ে যান এবং তারিখ-সময় লজিক দক্ষতার সাথে এবং নিরাপদে হ্যান্ডেল করুন
নিম্নলিখিত পাঠকদের জন্য সুপারিশ করা হয়েছে
- জাভায় তারিখ এবং সময় নিরাপদে এবং পরিষ্কারভাবে হ্যান্ডেল করতে চান এমন ডেভেলপাররা
- LocalDateTime-কে সম্পূর্ণভাবে আয়ত্ত করতে চান এমন ব্যক্তিরা
- সিস্টেম ডিজাইন এবং উন্নয়নের জন্য তারিখ-সময় ব্যবস্থাপনায় সেরা অনুশীলন খুঁজছেন এমন ইঞ্জিনিয়াররা
- MySQL বা PostgreSQL-এর মতো ডাটাবেসের সাথে কাজ করা ডেভেলপাররা
- লিগ্যাসি API (Date / Calendar) থেকে মাইগ্রেশনের সাথে কষ্ট পাচ্ছেন এমন যেকোনো ব্যক্তি
এই নিবন্ধটি পড়ে আপনি জাভায় তারিখ এবং সময় হ্যান্ডেলিং নিয়ে চিন্তা করা বন্ধ করার জ্ঞান এবং আত্মবিশ্বাস অর্জন করবেন। LocalDateTime-এর মৌলিক বিষয় এবং এটি অন্যান্য সাধারণভাবে তুলনা করা ক্লাসগুলির থেকে পার্থক্য কী তা ব্যাখ্যা করে শুরু করি।
২. LocalDateTime কী? মৌলিক বিষয় এবং অন্যান্য ক্লাসগুলির থেকে পার্থক্য
LocalDateTime-এর মৌলিক ওভারভিউ
LocalDateTime হলো জাভা ৮-এ পরিচিত আধুনিক তারিখ এবং সময় API-এর অংশ, যা java.time প্যাকেজের অধীনে রয়েছে। এর মূল বৈশিষ্ট্য হলো এটি তারিখ এবং সময় উভয়ই একসাথে হ্যান্ডেল করতে পারে, বছর, মাস, দিন, ঘণ্টা, মিনিট, সেকেন্ড এবং ন্যানোসেকেন্ড পর্যন্ত মান সংরক্ষণ করে।
java.util.Date এবং Calendar-এর মতো লিগ্যাসি API-গুলির বিপরীতে, LocalDateTime-এ টাইম জোনের তথ্য থাকে না। এটি একটি সাধারণ স্থানীয় তারিখ এবং সময় প্রতিনিধিত্ব করার জন্য আদর্শ, যেমন একটি নির্ধারিত ইভেন্ট বা রেকর্ড যেমন “১০ জুলাই, ২০২৫, ১৫:৩০:০০,” যেখানে টাইম জোনগুলি অপ্রাসঙ্গিক।
আরেকটি গুরুত্বপূর্ণ বৈশিষ্ট্য হলো LocalDateTime অপরিবর্তনীয় এবং থ্রেড-নিরাপদ। যেকোনো পরিবর্তন একটি নতুন ইনস্ট্যান্স ফেরত দেয়, যা এটিকে মাল্টি-থ্রেডেড পরিবেশে ব্যবহারের জন্য নিরাপদ করে।
লিগ্যাসি API-গুলি এবং অন্যান্য তারিখ-সময় ক্লাসগুলির থেকে পার্থক্য
জাভা একাধিক তারিখ-সময় ক্লাস প্রদান করে, প্রত্যেকটি ভিন্ন উদ্দেশ্যে সেবা করে। নিম্নলিখিত টেবিলটি তাদের পার্থক্য এবং সাধারণ ব্যবহারের ক্ষেত্রগুলি সারাংশ করে।
| Class | Time Zone | Managed Data | Main Use Case |
|---|---|---|---|
| LocalDateTime | No | Date and time | Representing local date-time values |
| LocalDate | No | Date only | When only the date is needed |
| LocalTime | No | Time only | When only the time is needed |
| ZonedDateTime | Yes | Date, time, and time zone | When explicit time zone handling is required |
| OffsetDateTime | Yes (e.g., +09:00) | Date, time, and offset | APIs or systems sensitive to time differences |
| Date / Calendar | Varies | Date and time | Legacy APIs (not recommended today) |
মূল পয়েন্টগুলি
- টাইম জোনগুলি গুরুত্বপূর্ণ হলে ZonedDateTime বা OffsetDateTime ব্যবহার করুন
- শুধুমাত্র তারিখ বা সময় প্রয়োজন হলে LocalDate বা LocalTime ব্যবহার করুন
- টাইম জোন ছাড়া স্থানীয় তারিখ এবং সময় পরিচালনার জন্য LocalDateTime ব্যবহার করুন
LocalDateTime-এর সাধারণ ব্যবহারের ক্ষেত্র
- সিডিউলিং সিস্টেম এবং টাস্ক ডেডলাইন
- স্থানীয় সময়ে লগিং এবং অডিট রেকর্ড
- ডাটাবেস DATETIME কলামের সাথে ইন্টিগ্রেশন
বিভিন্ন সার্ভার বা অঞ্চলের ব্যবহারকারীদের সাথে কাজ করার সময় টাইম জোন হ্যান্ডেলিং গুরুত্বপূর্ণ হয়ে ওঠে। এমন ক্ষেত্রে, ZonedDateTime ব্যবহার করার বিষয় বিবেচনা করুন।
৩. LocalDateTime ইনস্ট্যান্স কীভাবে তৈরি করবেন (কোড উদাহরণ সহ)
LocalDateTime-এর সাথে শুরু করার সময়, প্রথম জিনিসগুলির মধ্যে একটি হলো ইনস্ট্যান্স তৈরি করার উপায় শেখা। এই বিভাগটি সবচেয়ে সাধারণভাবে ব্যবহৃত তৈরির পদ্ধতিগুলি বাস্তব উদাহরণ সহ পরিচয় করায়।
৩-১. বর্তমান তারিখ এবং সময় পাওয়া (now)
সবচেয়ে সহজ ব্যবহার হলো বর্তমান স্থানীয় তারিখ এবং সময় পুনরুদ্ধার করা। কোনো টাইম জোন অন্তর্ভুক্ত না হলেও, মানটি সিস্টেমের ডিফল্ট টাইম জোনের উপর ভিত্তি করে।
import java.time.LocalDateTime;
LocalDateTime now = LocalDateTime.now();
System.out.println(now); // Example: 2025-07-10T15:30:45.123
৩-২. একটি নির্দিষ্ট তারিখ এবং সময় তৈরি করা (of)
একটি নির্দিষ্ট তারিখ ও সময় তৈরি করতে, of() মেথড ব্যবহার করুন। আপনি সেকেন্ড এবং ন্যানোসেকেন্ড পর্যন্ত মান নির্ধারণ করতে পারেন (যা ঐচ্ছিক)।
LocalDateTime dateTime = LocalDateTime.of(2025, 7, 10, 15, 30, 0);
System.out.println(dateTime); // 2025-07-10T15:30
3-3. স্ট্রিং থেকে তৈরি (parse)
LocalDateTime-ও ISO-8601 ফরম্যাটের (যেমন, "2025-07-10T15:30:00") অথবা কাস্টম ফরম্যাটের স্ট্রিং থেকে তৈরি করা যায়।
স্ট্যান্ডার্ড ISO ফরম্যাট ব্যবহার করে:
LocalDateTime parsed = LocalDateTime.parse("2025-07-10T15:30:00");
System.out.println(parsed); // 2025-07-10T15:30
কাস্টম ফরম্যাট ব্যবহার করে (DateTimeFormatter সহ):
import java.time.format.DateTimeFormatter;
String input = "2025/07/10 15:30:00";
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy/MM/dd HH:mm:ss");
LocalDateTime parsedCustom = LocalDateTime.parse(input, formatter);
System.out.println(parsedCustom); // 2025-07-10T15:30
3-4. সাধারণ ত্রুটি: DateTimeParseException
parse() ব্যবহার করার সময় প্রায়ই দেখা যায় এমন একটি ত্রুটি হল DateTimeParseException। মূল কারণ হল ইনপুট স্ট্রিং ফরম্যাট এবং ফরম্যাটার-এর মধ্যে অমিল।
উদাহরণ:
LocalDateTime.parse("2025/07/10 15:30:00");
// Error: not in ISO-8601 format
সমাধান:
- ফরম্যাট ISO-8601 না হলে সর্বদা একটি
DateTimeFormatterনির্দিষ্ট করুন। - সম্ভব হলে আগে থেকেই ইনপুট স্ট্রিং যাচাই করুন।
সারাংশ
- বর্তমান তারিখ ও সময়ের জন্য
LocalDateTime.now()ব্যবহার করুন - নির্দিষ্ট তারিখ-সময় তৈরি করতে
of()ব্যবহার করুন - স্ট্রিংয়ের জন্য
DateTimeFormatterসহparse()ব্যবহার করুন - পার্সিং ত্রুটি এড়াতে ফরম্যাটের সামঞ্জস্য নিশ্চিত করুন
4. LocalDateTime ফরম্যাটিং এবং স্ট্রিং-এ রূপান্তর
জাভাতে তারিখ ও সময় ডেটা পরিচালনা করার সময় আপনাকে প্রায়ই ডিসপ্লে ফরম্যাট এবং ইনপুট/আউটপুট ফরম্যাট-এর দিকে মনোযোগ দিতে হয়। যদিও LocalDateTime ডিফল্টভাবে ISO-8601 ফরম্যাটে আউটপুট দেয় (যেমন, 2025-07-10T15:30:00), বাস্তবিক অ্যাপ্লিকেশনগুলো প্রায়ই কাস্টম ফরম্যাটিং প্রয়োজন করে। এই অংশে LocalDateTime মানগুলো কীভাবে ফরম্যাট করতে হয় এবং কী বিষয়ে সতর্ক থাকতে হবে তা ব্যাখ্যা করা হয়েছে।
4-1. ডিফল্ট আউটপুট এবং ISO-8601 ফরম্যাট
System.out.println() ব্যবহার করে সরাসরি একটি LocalDateTime ইনস্ট্যান্স আউটপুট করলে, তা ISO-8601 ফরম্যাট YYYY-MM-DDTHH:MM:SS-এ প্রদর্শিত হয়। T অক্ষরটি তারিখ ও সময়ের মধ্যে বিভাজক হিসেবে ISO মানদণ্ডে নির্ধারিত।
LocalDateTime now = LocalDateTime.now();
System.out.println(now); // Example: 2025-07-10T15:30:45.123
4-2. কাস্টম ফরম্যাটে রূপান্তর (DateTimeFormatter ব্যবহার করে)
ব্যবসায়িক অ্যাপ্লিকেশন এবং ডেটাবেস ইন্টিগ্রেশনে প্রায়ই কাস্টম বা অঞ্চল-নির্দিষ্ট ফরম্যাট প্রয়োজন হয়। এমন ক্ষেত্রে DateTimeFormatter ক্লাস ব্যবহার করুন।
উদাহরণ: জাপানে সাধারণত ব্যবহৃত প্যাটার্ন
import java.time.format.DateTimeFormatter;
LocalDateTime dateTime = LocalDateTime.of(2025, 7, 10, 15, 30, 0);
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy/MM/dd HH:mm:ss");
String formatted = dateTime.format(formatter);
System.out.println(formatted); // 2025/07/10 15:30:00
আপনি অন্যান্য ফরম্যাটও স্বাধীনভাবে নির্ধারণ করতে পারেন, যেমন:
"yyyy年MM月dd日 HH時mm分ss秒""yyyyMMdd_HHmmss"
4-3. আউটপুটে “T” থাকা ও না থাকা কখন
toString()বাDateTimeFormatter.ISO_LOCAL_DATE_TIMEব্যবহার করলে “T” দেখা যায়।- কাস্টম ফরম্যাট প্যাটার্ন নির্ধারণ করে “T” সরানো যায়।
উদাহরণ: “T” ছাড়া আউটপুট
DateTimeFormatter noT = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
System.out.println(dateTime.format(noT)); // 2025-07-10 15:30:00
4-4. স্ট্রিংকে আবার LocalDateTime-এ রূপান্তর
সেকশন ৩-এ উল্লেখিত অনুযায়ী, কাস্টম ফরম্যাটের স্ট্রিংকে আবার LocalDateTime-এ রূপান্তর করতে DateTimeFormatter সহ parse() ব্যবহার করতে হয়।
String input = "2025/07/10 15:30:00";
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy/MM/dd HH:mm:ss");
LocalDateTime parsed = LocalDateTime.parse(input, formatter);
System.out.println(parsed); // 2025-07-10T15:30
সারাংশ
- ডিফল্ট আউটপুট ISO-8601 ( “T” সহ) অনুসরণ করে
- কাস্টম আউটপুট ফরম্যাটের জন্য
DateTimeFormatterব্যবহার করুন - ফরম্যাটার ব্যবহার করে নিরাপদে স্ট্রিংগুলোকে LocalDateTime-এ পার্স করুন
- ব্যবসা ও ইন্টিগ্রেশন চাহিদা পূরণের জন্য ফরম্যাটগুলোকে নমনীয়ভাবে কাস্টমাইজ করুন
5. তারিখ ও সময় যোগ, বিয়োগ এবং তুলনা (প্র্যাকটিসে সাধারণ)
বাস্তব জগতে অ্যাপ্লিকেশনগুলোতে “কয়েক দিন পরের তারিখ হিসাব করা” বা “দুটি তারিখ-সময় মান তুলনা করা” এর মতো অপারেশন করা সাধারণ। LocalDateTime এই অপারেশনগুলোর জন্য স্বজ্ঞাত API প্রদান করে।
5-1. তারিখ-সময় মান যোগ ও বিয়োগ (plus / minus)
LocalDateTime সময় ইউনিট যোগ ও বিয়োগের জন্য সমৃদ্ধ মেথড সরবরাহ করে। নিচে কিছু সাধারণ উদাহরণ দেওয়া হল।
যোগের উদাহরণ:
LocalDateTime base = LocalDateTime.of(2025, 7, 10, 15, 30, 0);
LocalDateTime plusDays = base.plusDays(5); // 5 days later
LocalDateTime plusHours = base.plusHours(3); // 3 hours later
LocalDateTime plusMonths = base.plusMonths(1); // 1 month later
System.out.println(plusDays); // 2025-07-15T15:30
System.out.println(plusHours); // 2025-07-10T18:30
System.out.println(plusMonths); // 2025-08-10T15:30
বিয়োগের উদাহরণ:
LocalDateTime minusDays = base.minusDays(2); // 2 days earlier
LocalDateTime minusMinutes = base.minusMinutes(45); // 45 minutes earlier
System.out.println(minusDays); // 2025-07-08T15:30
System.out.println(minusMinutes); // 2025-07-10T14:45
5-2. তারিখ-সময় মান তুলনা (isBefore, isAfter, equals)
একটি তারিখ-সময় অন্যটির আগে, পরে বা সমান কিনা নির্ধারণ করতে নিম্নলিখিত মেথডগুলো ব্যবহার করুন।
LocalDateTime a = LocalDateTime.of(2025, 7, 10, 10, 0, 0);
LocalDateTime b = LocalDateTime.of(2025, 7, 10, 15, 0, 0);
System.out.println(a.isBefore(b)); // true
System.out.println(a.isAfter(b)); // false
System.out.println(a.equals(b)); // false
5-3. পার্থক্য গণনা (Duration বনাম Period)
দুটি তারিখ-সময় মানের মধ্যে পার্থক্য গণনা করতে হলে, আপনি কী মাপতে চান তার উপর নির্ভর করে Duration এবং Period এর মধ্যে নির্বাচন করুন।
- Duration : সময়-ভিত্তিক পার্থক্যের জন্য (সেকেন্ড, মিনিট, ঘন্টা)
- Period : তারিখ-ভিত্তিক পার্থক্যের জন্য (বছর, মাস, দিন)
উদাহরণ: Duration (সময় পার্থক্য)
import java.time.Duration;
LocalDateTime start = LocalDateTime.of(2025, 7, 10, 10, 0, 0);
LocalDateTime end = LocalDateTime.of(2025, 7, 10, 15, 0, 0);
Duration duration = Duration.between(start, end);
System.out.println(duration.toHours()); // 5
System.out.println(duration.toMinutes()); // 300
উদাহরণ: Period (তারিখ পার্থক্য)
import java.time.Period;
LocalDateTime dateTime1 = LocalDateTime.of(2025, 7, 10, 0, 0, 0);
LocalDateTime dateTime2 = LocalDateTime.of(2025, 8, 5, 0, 0, 0);
// Convert to LocalDate before calculating the difference
Period period = Period.between(dateTime1.toLocalDate(), dateTime2.toLocalDate());
System.out.println(period.getMonths()); // 0
System.out.println(period.getDays()); // 26
সারাংশ
- সহজ গাণিতিক অপারেশনের জন্য
plusএবংminusব্যবহার করুন isBeforeএবংisAfterব্যবহার করে তারিখ-সময় মান তুলনা করুন- সময়-ভিত্তিক পার্থক্যের জন্য Duration এবং তারিখ-ভিত্তিক পার্থক্যের জন্য Period ব্যবহার করুন
- এই API গুলোকে একত্রিত করলে ব্যবসায়িক লজিক পরিষ্কার ও পাঠযোগ্য থাকে
6. LocalDateTime-কে অন্যান্য ক্লাস ও ডাটাবেস টাইপে রূপান্তর করা
ব্যবসা সিস্টেম বা বিদ্যমান অ্যাপ্লিকেশনের সাথে ইন্টিগ্রেট করার সময়, LocalDateTime-কে অন্যান্য তারিখ-সময় ক্লাস বা ডাটাবেস টাইপে রূপান্তর করা খুবই সাধারণ। এই অংশে প্রায়ই ব্যবহৃত রূপান্তর প্যাটার্ন এবং গুরুত্বপূর্ণ বিষয়গুলো সংক্ষেপে উপস্থাপন করা হয়েছে।
6-1. LocalDate এবং LocalTime এর মধ্যে রূপান্তর
যদিও LocalDateTime তারিখ ও সময় উভয়ই প্রতিনিধিত্ব করে, অনেক ক্ষেত্রে কেবল তারিখ বা কেবল সময় পরিচালনা করতে হয়।
LocalDateTime → LocalDate / LocalTime
LocalDateTime dateTime = LocalDateTime.of(2025, 7, 10, 15, 30, 0);
LocalDate date = dateTime.toLocalDate();
LocalTime time = dateTime.toLocalTime();
System.out.println(date); // 2025-07-10
System.out.println(time); // 15:30
LocalDate / LocalTime → LocalDateTime
LocalDate date = LocalDate.of(2025, 7, 10);
LocalTime time = LocalTime.of(15, 30);
LocalDateTime dateTime = LocalDateTime.of(date, time);
System.out.println(dateTime); // 2025-07-10T15:30
6-2. Converting with java.util.Date, Calendar, and java.sql.Timestamp
When working with legacy APIs or JDBC, you may need to convert between LocalDateTime and older date-time types such as Date or Timestamp.
LocalDateTime → java.sql.Timestamp
import java.sql.Timestamp;
import java.time.LocalDateTime;
LocalDateTime dateTime = LocalDateTime.now();
Timestamp timestamp = Timestamp.valueOf(dateTime);
System.out.println(timestamp); // Example: 2025-07-10 15:30:00.123
java.sql.Timestamp → LocalDateTime
Timestamp timestamp = Timestamp.valueOf("2025-07-10 15:30:00");
LocalDateTime dateTime = timestamp.toLocalDateTime();
System.out.println(dateTime); // 2025-07-10T15:30
Converting java.util.Date or Calendar requires an intermediate Instant
Date date = new Date();
LocalDateTime dateTime =
date.toInstant()
.atZone(ZoneId.systemDefault())
.toLocalDateTime();
6-3. Mapping to Database DATETIME Types (MySQL / PostgreSQL)
LocalDateTime works very well with DATETIME columns in MySQL and PostgreSQL. Using JDBC drivers, you can convert smoothly via setTimestamp and getTimestamp.
- MySQL / PostgreSQL
DATETIME↔ JavaLocalDateTimeorjava.sql.Timestamp - When reading: use
getTimestamp()→toLocalDateTime() - When writing: convert with
Timestamp.valueOf(LocalDateTime)and usesetTimestamp()
Important: Be careful with time zone management
- DATETIME columns in MySQL and PostgreSQL do not store time zone information.
- It is critical to keep a consistent time zone policy within the application.
- If strict time zone control is required, consider
TIMESTAMP WITH TIME ZONEor usingZonedDateTime.

6-4. Converting with ZonedDateTime and OffsetDateTime
When time zone information is required, conversions between LocalDateTime and ZonedDateTime are commonly used.
LocalDateTime localDateTime = LocalDateTime.now();
ZoneId zone = ZoneId.of("Asia/Tokyo");
ZonedDateTime zonedDateTime = localDateTime.atZone(zone);
System.out.println(zonedDateTime); // 2025-07-10T15:30+09:00[Asia/Tokyo]
LocalDateTime backToLocal = zonedDateTime.toLocalDateTime();
System.out.println(backToLocal); // 2025-07-10T15:30
Summary
LocalDateTimecan be easily converted to and from other date-time classes and database types- JDBC integration works smoothly via
Timestamp - Use
ZonedDateTimeorOffsetDateTimewhen time zone handling is required - Ensure time zone consistency when integrating with databases
7. Practical Use Cases and Quick Reference by Scenario
This section organizes real-world use cases for LocalDateTime and helps you choose the appropriate class depending on the situation.
7-1. Common Practical Use Cases
(1) Task and Schedule Management Systems
LocalDateTime is ideal when managing schedules and deadlines that require both date and time. It allows intuitive handling of task start and end times.
LocalDateTime deadline =
LocalDateTime.of(2025, 7, 31, 23, 59, 59);
(2) Attendance and Time Tracking
Clock-in and clock-out records require both date and time. Integration with database DATETIME columns is straightforward.
LocalDateTime clockIn = LocalDateTime.now();
(3) Logging and Audit Trails
System logs and error histories often record event timestamps using LocalDateTime. It is suitable when time zone adjustments are unnecessary or logs are internal to the application.
7-2. ব্যবহার কেস অনুযায়ী দ্রুত রেফারেন্স টেবিল
| Use Case | Recommended Class | Reason |
|---|---|---|
| Store local date and time | LocalDateTime | Best choice when time zones are not required |
| Date only | LocalDate | Calendars, birthdays, etc. |
| Time only | LocalTime | Alarms, business hours |
| Explicit time zone management | ZonedDateTime | Multi-region systems |
| Use UTC or offsets | OffsetDateTime | APIs and external integrations |
7-3. আপনাকে কখন টাইম জোনের প্রয়োজন এবং কখন নয়
টাইম জোনের প্রয়োজন না থাকা সাধারণ ক্ষেত্রে
- অ্যাপ্লিকেশনের মধ্যে শুধুমাত্র ব্যবহৃত তারিখ-সময় মান
- একক-অবস্থান সিস্টেম (যেমন, শুধুমাত্র দেশীয় সেবা)
টাইম জোনের প্রয়োজনীয় সাধারণ ক্ষেত্রে
- বহু অঞ্চল বা আন্তর্জাতিক ব্যবহারকারী জড়িত সিস্টেম
- বিভিন্ন টাইম জোনে চলমান সার্ভার
- ব্যবহারকারীর অবস্থানের ভিত্তিতে সময় ভিন্নভাবে প্রদর্শনকারী অ্যাপ্লিকেশন
সিদ্ধান্ত নির্দেশিকা
নিজেকে জিজ্ঞাসা করুন: “এই তারিখ-সময় কি একটি নির্দিষ্ট মুহূর্তকে প্রতিনিধিত্ব করে?” যদি হ্যাঁ হয়, তবে ZonedDateTime অথবা OffsetDateTime ব্যবহার করুন।
7-4. সহজ ক্লাস নির্বাচন প্রবাহ
- তারিখ-সময় কি টাইম জোন সচেতনতা প্রয়োজন?
- হ্যাঁ →
ZonedDateTimeঅথবাOffsetDateTime - না → ধাপ ২ তে যান
- আপনার কি শুধুমাত্র তারিখ, শুধুমাত্র সময়, নাকি উভয়ই প্রয়োজন?
- শুধুমাত্র তারিখ →
LocalDate - শুধুমাত্র সময় →
LocalTime - তারিখ এবং সময় →
LocalDateTime
সারসংক্ষেপ
LocalDateTimeটাইম জোন ছাড়া স্থানীয় তারিখ ও সময় পরিচালনার জন্য আদর্শ- সঠিক ক্লাস নির্বাচন সিস্টেম ডিজাইন ও রক্ষণাবেক্ষণকে সহজ করে
- প্রয়োজনীয়তা স্পষ্টভাবে বোঝা ভবিষ্যতের বাগ ও অসঙ্গতি এড়াতে সহায়তা করে
8. সাধারণ ত্রুটি, সমস্যার সমাধান, এবং সমাধান
LocalDateTime ব্যবহার করার সময়, ডেভেলপাররা প্রায়ই পুনরাবৃত্ত ত্রুটি বা বিভ্রান্তির উৎসের সম্মুখীন হন। এই বিভাগটি সাধারণ সমস্যাগুলি এবং তাদের সমাধানকে প্রশ্নোত্তর ফরম্যাটে সংক্ষেপে উপস্থাপন করে, যাতে সমস্যার উদ্ভব হলে দ্রুত প্রতিক্রিয়া জানাতে পারেন।
প্রশ্ন ১. DateTimeParseException ঘটেছে
কারণ
- এই এক্সসেপশন ঘটে যখন
LocalDateTime.parse()‑এ পাঠানো স্ট্রিং প্রত্যাশিত ফরম্যাটের সাথে মেলে না। - যেসব স্ট্রিং ISO-8601 ফরম্যাটে নয় (যেমন,
"2025-07-10T15:30:00") সেগুলির জন্যDateTimeFormatterপ্রয়োজন।
সমাধান
- সদা নিশ্চিত করুন যে ফরম্যাট মেলে এবং প্রয়োজনে
DateTimeFormatterব্যবহার করুন।String input = "2025/07/10 15:30:00"; DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy/MM/dd HH:mm:ss"); LocalDateTime.parse(input, formatter); // OK
প্রশ্ন ২. NullPointerException থেকে সতর্ক থাকুন
কারণ
- একটি null
LocalDateTimeরেফারেন্সে মেথড কল করা।
সমাধান
- ব্যবহারের আগে null মান আছে কিনা পরীক্ষা করুন।
Optional‑এ মানগুলো মোড়ানোও কার্যকর হতে পারে।
প্রশ্ন ৩. ভুল টাইম জোন হ্যান্ডলিং
কারণ
LocalDateTimeটাইম জোন তথ্য সংরক্ষণ করে না, তাই সিস্টেম বা ডাটাবেসের টাইম জোন পরিবর্তন অপ্রত্যাশিত ফলাফল দিতে পারে।
সমাধান
- সার্ভার এবং ডাটাবেসের টাইম জোন সেটিংস একত্রিত করুন।
- টাইম জোনের সঠিকতা প্রয়োজন হলে
ZonedDateTimeঅথবাOffsetDateTimeব্যবহার করুন।
প্রশ্ন ৪. ডাটাবেসের সাথে ইন্টিগ্রেট করার সময় তারিখ-সময় মান পরিবর্তিত হয়
কারণ
- ডাটাবেস কলাম টাইপ বা টাইম জোন সেটিংস এবং জাভা অ্যাপ্লিকেশন সেটিংসের মধ্যে অমিল।
সমাধান
DATETIMEএবংLocalDateTimeব্যবহার করার সময় টাইম জোনের ভিত্তি স্পষ্টভাবে নির্ধারণ করুন।- কড়া সঠিকতা প্রয়োজন হলে
TIMESTAMP WITH TIME ZONEঅথবাZonedDateTimeব্যবহার বিবেচনা করুন।
প্রশ্ন ৫. নির্ভুলতার ক্ষতি (মিলিসেকেন্ড / ন্যানোসেকেন্ড)
কারণ
- কিছু JDBC ড্রাইভার বা ডাটাবেস শুধুমাত্র মিলিসেকেন্ড নির্ভুলতা সমর্থন করে, ন্যানোসেকেন্ড কেটে দেয়।
সমাধান
- আপনার সিস্টেমের প্রয়োজনীয়তায় এই নির্ভুলতা ক্ষতি গ্রহণযোগ্য কিনা নিশ্চিত করুন।
- যদি ন্যানোসেকেন্ড নির্ভুলতা বাধ্যতামূলক হয় তবে বিকল্প হ্যান্ডলিং ব্যবহার করুন।
প্রশ্ন ৬. লিগেসি API (Date, Calendar) থেকে রূপান্তর করার সময় ত্রুটি
কারণ
DateঅথবাCalendarসরাসরিLocalDateTime‑এ রূপান্তর করার চেষ্টা করা।
সমাধান
- সদা
InstantএবংZoneIdএর মাধ্যমে রূপান্তর করুন।Date date = new Date(); LocalDateTime dateTime = date.toInstant() .atZone(ZoneId.systemDefault()) .toLocalDateTime();
প্রায়োগিক ডেভেলপমেন্ট টিপস
- বেশিরভাগ সমস্যার প্রতিরোধের জন্য ফরম্যাটিং, টাইম জোন এবং নাল চেক-এ মনোযোগ দিন
- ডেটাবেস বা অন্যান্য সিস্টেমের সাথে ইন্টিগ্রেট করার সময় টাইপ এবং কনফিগারেশন সামঞ্জস্যতা সর্বদা যাচাই করুন
- ত্রুটি ঘটলে, এক্সসেপশন মেসেজগুলো সতর্কতার সাথে পড়ুন এবং ইনপুট ভ্যালু, কনভার্সন লজিক এবং পরিবেশ সেটিংস পর্যালোচনা করুন
9. প্রায়শই জিজ্ঞাসিত প্রশ্নাবলী (FAQ)
এই বিভাগটি বাস্তবিক ডেভেলপমেন্ট পরিস্থিতিতে প্রায়শই উদ্ভূত LocalDateTime সম্পর্কিত প্রশ্নের উত্তর দেয়। সমস্যার সমাধান বা সিস্টেম ডিজাইন করার সময় দ্রুত রেফারেন্স হিসেবে এটি ব্যবহার করুন।
Q1. LocalDateTime কি টাইম জোন হ্যান্ডল করতে পারে?
না। LocalDateTime টাইম জোন তথ্য সংরক্ষণ করে না। যদি আপনাকে সময়ের নির্দিষ্ট মুহূর্ত পরিচালনা করতে হয়, তবে ZonedDateTime অথবা OffsetDateTime ব্যবহার করুন।
Q2. Date / Calendar থেকে LocalDateTime-এ মাইগ্রেট করার সবচেয়ে নিরাপদ উপায় কী?
আপনি সরাসরি Date বা Calendar রূপান্তর করতে পারবেন না। সর্বদা Instant এবং ZoneId এর মাধ্যমে রূপান্তর করুন।
Date date = new Date();
LocalDateTime dateTime =
date.toInstant()
.atZone(ZoneId.systemDefault())
.toLocalDateTime();
Q3. আউটপুটে কখনও কখনও “T” কেন থাকে?
“T” অক্ষরটি ISO-8601 মানের সেপারেটর। এটি toString() অথবা DateTimeFormatter.ISO_LOCAL_DATE_TIME ব্যবহার করার সময় দেখা যায়। এটি সরাতে, একটি কাস্টম ফরম্যাট প্যাটার্ন নির্ধারণ করুন।
Q4. ডেটাবেসে মান সংরক্ষণ করার সময় কী বিষয়ে সতর্ক থাকা উচিত?
ডেটাবেসের DATETIME কলামগুলো টাইম জোন তথ্য সংরক্ষণ করে না। অ্যাপ্লিকেশনটি একক টাইম জোন ধারাবাহিকভাবে ব্যবহার করে তা নিশ্চিত করুন। যদি কঠোর নির্ভুলতা প্রয়োজন হয়, তবে TIMESTAMP WITH TIME ZONE অথবা ZonedDateTime ব্যবহার করার কথা বিবেচনা করুন।
Q5. LocalDateTime কতটা প্রিসিশন সমর্থন করে?
LocalDateTime ন্যানোসেকেন্ড প্রিসিশন সমর্থন করে। তবে, অনেক ডেটাবেস এবং JDBC ড্রাইভার শুধুমাত্র মিলিসেকেন্ড সমর্থন করে, যা সূক্ষ্ম প্রিসিশনকে কেটে দিতে পারে।
Q6. LocalDateTime কি ডেলাইট সেভিং টাইম (DST) দ্বারা প্রভাবিত হয়?
না। LocalDateTime নিজে ডেলাইট সেভিং সমন্বয় প্রয়োগ করে না। যদি DST হ্যান্ডলিং প্রয়োজন হয়, তবে ZonedDateTime ব্যবহার করুন।
Q7. যদি শুধুমাত্র তারিখ বা সময় দরকার হয়, আমি কী ব্যবহার করব?
শুধুমাত্র তারিখের জন্য LocalDate এবং শুধুমাত্র সময়ের জন্য LocalTime ব্যবহার করুন। উভয়ই প্রয়োজন হলে LocalDateTime আদর্শ।
Q8. এক্সসেপশন কীভাবে হ্যান্ডল করা উচিত?
এক্সসেপশন মেসেজগুলো সতর্কতার সাথে পড়ুন এবং যাচাই করুন:
- স্ট্রিং ফরম্যাট সঠিক কিনা
- নাল বা অবৈধ মান আছে কিনা
- কনভার্সন ধাপগুলো সঠিকভাবে বাস্তবায়িত হয়েছে কিনা
10. সারাংশ এবং রেফারেন্স লিঙ্ক
এই প্রবন্ধে LocalDateTime এর মৌলিক বিষয় থেকে ব্যবহারিক প্রয়োগ, সাধারণ সমস্যাবলি এবং প্রায়শই জিজ্ঞাসিত প্রশ্ন পর্যন্ত সবকিছু আলোচনা করা হয়েছে। নিচে সংক্ষিপ্ত সারাংশ এবং আরও শিখতে সহায়ক রেফারেন্সগুলো দেওয়া হল।
10-1. LocalDateTime সঠিকভাবে ব্যবহার করার মূল টেকঅ্যাওয়ে
- LocalDateTime হল একটি নিরাপদ এবং স্বজ্ঞাত ক্লাস, যা টাইম জোন ছাড়া স্থানীয় তারিখ ও সময় পরিচালনা করে। এটি গাণিতিক অপারেশন, ফরম্যাটিং, তুলনা এবং পার্সিং সহজে সমর্থন করে।
- সিস্টেমের চাহিদা অনুযায়ী উপযুক্ত তারিখ-সময় ক্লাস নির্বাচন করুন।
- শুধুমাত্র তারিখের জন্য
LocalDateব্যবহার করুন - শুধুমাত্র সময়ের জন্য
LocalTimeব্যবহার করুন - টাইম জোন গুরুত্বপূর্ণ হলে
ZonedDateTimeঅথবাOffsetDateTimeব্যবহার করুন - ডেটাবেস বা বাহ্যিক সিস্টেমের সাথে ইন্টিগ্রেট করার সময় টাইম জোন এবং ফরম্যাটে বিশেষ মনোযোগ দিন।
- সাধারণ ত্রুটিগুলো আগে থেকেই বুঝে নিলে সমস্যার প্রতিরোধ হয়। দ্রুত সমাধানের জন্য FAQ এবং ট্রাবলশুটিং সেকশন দেখুন।
10-2. রেফারেন্স লিঙ্ক এবং ডকুমেন্টেশন
- Java SE 8 API ডকুমেন্টেশন (LocalDateTime)
- DateTimeFormatter অফিসিয়াল ডকুমেন্টেশন
- Oracle Java তারিখ ও সময় API গাইড
- Java তারিখ ও সময় API ওভারভিউ (বাহ্যিক আর্টিকেল)
10-3. ডেভেলপারদের জন্য চূড়ান্ত নোট
এই প্রবন্ধের জ্ঞান দিয়ে, আপনাকে আর LocalDateTime ব্যবহার নিয়ে সংগ্রাম করতে হবে না। নতুন চাহিদা উদ্ভব হলে, সর্বদা অফিসিয়াল ডকুমেন্টেশন এবং বিশ্বাসযোগ্য প্রযুক্তিগত সম্পদগুলোর দিকে রেফার করুন যাতে আপডেটেড থাকতে পারেন।
সঠিক ধারণা এবং সেরা অনুশীলন প্রয়োগ করে, আপনি জাভা তারিখ‑সময় হ্যান্ডলিংকে আরও নিরাপদ, পরিষ্কার এবং বাস্তবিক সিস্টেমে আরও রক্ষণাবেক্ষণযোগ্য করতে পারেন।

