আমি ডকুমেন্টেশনটি পড়েছি, তবে যখন আমি একটি বা অন্যটি ব্যবহার করা উচিত তখনও আমি তা পেতে পারি না:
ডকুমেন্টেশন অনুসারে OffsetDateTime
ডাটাবেসে তারিখ লেখার সময় ব্যবহার করা উচিত, তবে আমি তা পাই না।
আমি ডকুমেন্টেশনটি পড়েছি, তবে যখন আমি একটি বা অন্যটি ব্যবহার করা উচিত তখনও আমি তা পেতে পারি না:
ডকুমেন্টেশন অনুসারে OffsetDateTime
ডাটাবেসে তারিখ লেখার সময় ব্যবহার করা উচিত, তবে আমি তা পাই না।
উত্তর:
প্রশ্ন: জাভা 8 জোনেডেটটাইম এবং অফসেটডেটটাইমের মধ্যে পার্থক্য কী?
জাভাদোকরা এটি বলেছেন:
"
OffsetDateTime
,ZonedDateTime
এবংInstant
সমস্ত ন্যানোসেকেন্ডের নির্ভুলতার জন্য সময়রেখায় একটি তাত্ক্ষণিক স্টোরInstant
।OffsetDateTime
তাত্ক্ষণিক ইউটিসি / গ্রীনিচ, যা স্থানীয় তারিখ-সময় প্রাপ্ত করা করার অনুমতি দেয় থেকে অফসেট। যোগZonedDateTime
পূর্ণকালীন যোগ -জোন বিধি। "
সূত্র: https://docs.oracle.com/javase/8/docs/api/java/time/OffsetDateTime.html
এইভাবে পার্থক্য OffsetDateTime
এবং ZonedDateTime
যে আধুনিক সেই সময় সমন্বয় এবং অন্যান্য বিভিন্ন ব্যতিক্রমসমূহ কভার দিবালোক সঞ্চয় নিয়ম রয়েছে।
সহজভাবে স্থিত:
সময় অঞ্চল = ( অফসেট থেকে-ইউটিসি + বিধি-বিধিবিধানের জন্য)
প্রশ্ন: ডকুমেন্টেশন অনুযায়ী
OffsetDateTime
ডাটাবেসে তারিখ লেখার সময় ব্যবহার করা উচিত, তবে আমি তা পাই না।
স্থানীয় সময় অফসেট সহ তারিখগুলি সর্বদা সময়ে একই তাত্ক্ষণিক প্রতিনিধিত্ব করে এবং তাই স্থিতিশীল ক্রম রয়েছে। বিপরীতে, পূর্ণ সময় অঞ্চল তথ্য সহ খেজুর অর্থ সম্পর্কিত সময় অঞ্চলগুলির জন্য বিধিগুলির সামঞ্জস্যের মুখে অস্থির। (এবং এটি ঘটে; যেমন ভবিষ্যতে তারিখ-সময়ের মানগুলির জন্য)) সুতরাং আপনি যদি সংরক্ষণ এবং তারপরে কোনও পুনরুদ্ধার করেন ZonedDateTime
তবে বাস্তবায়নের ক্ষেত্রে সমস্যা রয়েছে:
এটি গণিত অফসেট সংরক্ষণ করতে পারে ... এবং পুনরুদ্ধার করা অবজেক্টটির পরে একটি অফসেট থাকতে পারে যা জোন-আইডির জন্য বর্তমান নিয়মের সাথে সঙ্গতিপূর্ণ নয়।
এটি গণিত অফসেটটি বাতিল করতে পারে ... এবং পুনরুদ্ধারকৃত অবজেক্টটি তার পরে সঞ্চিত একের চেয়ে পরম / সর্বজনীন টাইমলাইনে একটি পৃথক পয়েন্ট উপস্থাপন করে।
আপনি যদি জাভা অবজেক্ট সিরিয়ালাইজেশন ব্যবহার করেন তবে জাভা 9 বাস্তবায়ন প্রথম পন্থা নেয়। এটি হ্যান্ডেল করার পক্ষে এটি "আরও সঠিক" উপায়, তবে এটি ডকুমেন্টেড বলে মনে হয় না। (জেডিবিসি ড্রাইভার এবং ওআরএম বাইন্ডিং সম্ভবতঃ একই রকম সিদ্ধান্ত নিয়েছে, এবং আশা করি এটি সঠিকভাবে পাচ্ছে।)
তবে আপনি যদি এমন কোনও অ্যাপ্লিকেশন লিখছেন যা ম্যানুয়ালি তারিখ / সময় মানগুলি সঞ্চয় করে বা যা নির্ভর করে java.sql.DateTime
, তবে জোন-আইডির জটিলতাগুলি মোকাবেলা করা ... সম্ভবত কিছু এড়ানো উচিত। সুতরাং পরামর্শ।
নোট করুন যে সময়গুলির সাথে যার অর্থ / অর্ডারিং অস্থিতিশীল তা কোনও অ্যাপ্লিকেশনের জন্য সমস্যাযুক্ত হতে পারে । এবং যেহেতু জোন নিয়মে পরিবর্তনগুলি একটি প্রান্তের মামলা, তাই অপ্রত্যাশিত সময়ে সমস্যাগুলি উত্থাপনযোগ্য।
এ (সম্ভাব্য) পরামর্শের দ্বিতীয় কারণটি ZonedDateTime
হ'ল নির্দিষ্ট পয়েন্টগুলিতে একটি নির্মাণ অস্পষ্ট। উদাহরণস্বরূপ আপনি যখন "ঘড়িগুলি পিছনে রাখছেন" সময়কালে স্থানীয় সময় এবং একটি অঞ্চল-আইডি সংমিশ্রণ আপনাকে দুটি পৃথক অফসেট দিতে পারে। প্রতিশ্রুতি ZonedDateTime
নিয়মিতভাবে অন্যটিকে বেছে নেবে ... তবে এটি সর্বদা সঠিক পছন্দ নয়।
এখন, কোনও অ্যাপ্লিকেশনগুলির জন্য সমস্যা হতে পারে ZonedDateTime
যা সেভাবে মানগুলি তৈরি করে। কারও দৃষ্টিকোণ থেকে একটি এন্টারপ্রাইজ অ্যাপ্লিকেশন তৈরি করা তখন একটি বড় সমস্যা হয় যখন (সম্ভবত ভুল) ZonedDateTime
মানগুলি স্থির থাকে এবং পরে ব্যবহৃত হয়।
ZonedDateTime
একটিতে আমি যা পড়ি তা থেকে ডিএসটি স্যুইচিং ইত্যাদি সহ টাইম অঞ্চলগুলি সম্পর্কিত তথ্য রয়েছে।