Mysql
 sql >> डेटाबेस >  >> RDS >> Mysql

एक्लिप्सलिंक और जोडा-टाइम का उपयोग कर डेटाबेस में यूटीसी में डेट-टाइम कैसे स्टोर करें?

तिथि जावा में टाइमज़ोन अज्ञेयवादी है। यह हमेशा UTC लेता है (डिफ़ॉल्ट रूप से और हमेशा) लेकिन जब Date / टाइमस्टैम्प एक JDBC ड्राइवर के माध्यम से एक डेटाबेस में भेजा जाता है, यह JVM समय क्षेत्र के अनुसार दिनांक / समय की व्याख्या करता है जो बदले में सिस्टम समय क्षेत्र (मूल ऑपरेटिंग सिस्टम ज़ोन) में डिफ़ॉल्ट होता है।

इसलिए, जब तक MySQL JDBC ड्राइवर को स्पष्ट रूप से UTC ज़ोन का उपयोग करने के लिए मजबूर नहीं किया गया था या JVM स्वयं उस ज़ोन का उपयोग करने के लिए सेट नहीं है, यह Date स्टोर नहीं करेगा। / टाइमस्टैम्प यूटीसी का उपयोग करते हुए लक्ष्य डेटाबेस में भले ही MySQL को default_time_zone='+00:00' का उपयोग करके यूटीसी का उपयोग करने के लिए कॉन्फ़िगर किया जाना था। my.ini . में या my.cnf [mysqld] . में खंड। Oracle जैसे कुछ डेटाबेस टाइम ज़ोन के साथ टाइम स्टैम्प का समर्थन कर सकते हैं और यह एक अपवाद हो सकता है जिससे मैं परिचित नहीं हूँ (अनचाहे क्योंकि मेरे पास वर्तमान में वह वातावरण नहीं है)।

void setTimestamp(int पैरामीटरIndex, Timestamp x, Calendar cal) SQLException को फेंकता है

इसे के आह्वान की जांच करके और स्पष्ट किया जा सकता है। सेटटाइमस्टैम्पइंटरनल () MySQL JDBC ड्राइवर कार्यान्वयन की विधि।

निम्नलिखित देखें दो setTimestampInternal() पर कॉल करता है setTimestamp() . के दो अतिभारित संस्करणों के भीतर से विधि विधि।

जब कोई कैलेंडर न हो उदाहरण PreparedStatement#setTimestamp() . के साथ निर्दिष्ट किया गया है विधि, डिफ़ॉल्ट समय क्षेत्र का उपयोग किया जाएगा (this.connection.getDefaultTimeZone() )।

एप्लिकेशन सर्वर में कनेक्शन पूल का उपयोग करते समय / कनेक्शन द्वारा समर्थित सर्वलेट कंटेनर / जेएनडीआई जैसे डेटा स्रोतों तक पहुंच या संचालन,

MySQL JDBC ड्राइवर को हमारी रुचि के वांछित समय क्षेत्र (UTC) का उपयोग करने के लिए मजबूर करने की आवश्यकता है, निम्नलिखित दो मापदंडों को कनेक्शन URL की क्वेरी स्ट्रिंग के माध्यम से आपूर्ति करने की आवश्यकता है।

<उप>मैं MySQL JDBC ड्राइवरों के इतिहास से परिचित नहीं हूँ, लेकिन MySQL ड्राइवरों के अपेक्षाकृत पुराने संस्करणों में, यह पैरामीटर useLegacyDatetimeCode आवश्यकता नहीं हो सकती है। इस प्रकार, किसी को उस स्थिति में स्वयं को समायोजित करने की आवश्यकता हो सकती है।

उदाहरण के लिए, एप्लिकेशन सर्वर, ग्लासफ़िश के मामले में, उन्हें JDBC क्षेत्र बनाते समय सर्वर के अंदर JDBC कनेक्शन पूल के साथ-साथ अन्य विन्यास योग्य गुणों के साथ या तो व्यवस्थापक वेब GUI टूल का उपयोग करके या domain.xml में सेट किया जा सकता है। सीधे। domain.xml निम्न जैसा दिखता है (XA डेटा स्रोत का उपयोग करके)।

 <संपत्ति का नाम="पासवर्ड" मान ="पासवर्ड">  <संपत्ति का नाम ="डेटाबेस नाम" मूल्य ="डेटाबेस_नाम">  <संपत्ति का नाम ="सर्वरनाम" मूल्य ="लोकलहोस्ट">  <संपत्ति का नाम ="user" value="root">          

WildFly के मामले में, उन्हें standalone-xx.yy.xml में कॉन्फ़िगर किया जा सकता है CLI कमांड का उपयोग करना या व्यवस्थापक वेब GUI टूल का उपयोग करना (XA डेटा स्रोत का उपयोग करना)।

 database_name localhost 3306 xa-datasource-property> true UTF-8  गलत UTC com.mysql.jdbc.jdbc2.Optional.MysqlXADataSource mysql TRANSACTION_READ_COMMITTED <एक्सए-पूल> <न्यूनतम-पूल-आकार>5 <अधिकतम-पूल-आकार>15  <सुरक्षा> <उपयोगकर्ता-नाम>रूट <पासवर्ड>पासवर्ड  <मान्यता> <वैध-कनेक्शन-जांचकर्ता वर्ग-नाम="org.jboss.jca.adapters.jdbc.extensions.mysql.MySQLValidConnectionChecker"/> <पृष्ठभूमि-सत्यापन>सत्य <अपवाद-सॉर्टर वर्ग-नाम="org.jboss.jca.adapters.jdbc.extensions.mysql.MySQLExceptionSorter"/>  <कथन> <शेयर-तैयार-कथन>सत्य    com.mysql.jdbc.Driver  

<उप>गैर-XA डेटा स्रोतों पर भी यही बात लागू होती है। उस स्थिति में उन्हें सीधे ही कनेक्शन URL में जोड़ा जा सकता है।

ये सभी उल्लिखित गुण जेडीबीसी ड्राइवर में उपलब्ध उल्लिखित वर्ग पर सेट किए जाएंगे, अर्थात् com.mysql.jdbc.jdbc2.Optional.MysqlXADataSource दोनों मामलों में इस वर्ग में अपने संबंधित सेटर विधियों का उपयोग करना।

उदाहरण के लिए, सीधे कोर JDBC API का उपयोग करने या टॉमकैट में कनेक्शन पूलिंग के मामले में, उन्हें सीधे कनेक्शन URL पर सेट किया जा सकता है (context.xml में) )

<संदर्भ antiJARLocking="true" path="/path">  का उपयोग करें 

अतिरिक्त :

यदि लक्ष्य डेटाबेस सर्वर डीएसटी-सेंसिबल ज़ोन पर चल रहा है और डेलाइट सेविंग टाइम (डीएसटी) बंद नहीं है, तो यह समस्याएँ पैदा करेगा। एक मानक समय क्षेत्र का उपयोग करने के लिए डेटाबेस सर्वर को भी बेहतर तरीके से कॉन्फ़िगर करें जो यूटीसी या जीएमटी जैसे डीएसटी से प्रभावित नहीं है। यूटीसी को आमतौर पर जीएमटी पर पसंद किया जाता है लेकिन इस संबंध में दोनों समान हैं। सीधे यह लिंक

वैसे, मैंने जेपीए 2.1 के बाद से, EclipseLink के मालिकाना कनवर्टर को छोड़ दिया है। अपना स्वयं का मानक कनवर्टर प्रदान करता है जिसे आवश्यकता पड़ने पर एक अलग जेपीए प्रदाता को पोर्ट किया जा सकता है, बिना थोड़े या बिना किसी संशोधन के। यह अब निम्न जैसा दिखता है जिसमें java.util.Date java.sql.Timestamp . द्वारा भी प्रतिस्थापित किया गया था ।

आयात करें सच) पब्लिक फाइनल क्लास JodaDateTimeConverter एट्रीब्यूट कन्वर्टर लागू करता है <डेटटाइम, टाइमस्टैम्प> {@ ओवरराइड पब्लिक टाइमस्टैम्प कन्वर्ट टूडेटाबेस कॉलम (डेटटाइम डेटटाइम) {रिटर्न डेटटाइम ==नल? शून्य:नया टाइमस्टैम्प (डेटटाइम.विथज़ोन (डेटटाइमज़ोन.यूटीसी)। getMillis ()); } @ ओवरराइड पब्लिक डेटटाइम कन्वर्ट टूएंटिटी एट्रिब्यूट (टाइमस्टैम्प टाइमस्टैम्प) {रिटर्न टाइमस्टैम्प ==अशक्त? शून्य:नया डेटटाइम (टाइमस्टैम्प, डेटटाइमज़ोन.यूटीसी); }}

तब यह पूरी तरह से संबंधित एप्लिकेशन क्लाइंट (सर्वलेट्स / जेएसपी / जेएसएफ / रिमोट डेस्कटॉप क्लाइंट आदि) की जिम्मेदारी है कि वह अंतिम उपयोगकर्ताओं को दिनांक / समय प्रदर्शित या प्रस्तुत करते समय एक उपयुक्त उपयोगकर्ता के समय क्षेत्र के अनुसार दिनांक / समय को परिवर्तित करें। संक्षिप्तता के लिए इस उत्तर में शामिल नहीं है और वर्तमान प्रश्न की प्रकृति के आधार पर ऑफ-विषय है।

कन्वर्टर में उन शून्य जांचों की भी आवश्यकता नहीं है क्योंकि यह पूरी तरह से संबद्ध एप्लिकेशन क्लाइंट (ग्राहकों) की जिम्मेदारी है जब तक कि कुछ फ़ील्ड वैकल्पिक न हों।

अब सब ठीक हो जाता है। किसी भी अन्य सुझाव/सुझावों का स्वागत है। मेरे किसी भी अज्ञानी की आलोचना का स्वागत है।



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. पायथन में mysql.connector के साथ प्रारूप-मापदंडों को संसाधित करने में विफल

  2. JPA/EclipseLink का उपयोग करके कैस्केड कैसे बने रहें?

  3. बहु-किरायेदार Django अनुप्रयोग:प्रति अनुरोध डेटाबेस कनेक्शन बदलना?

  4. MySQL में एक को छोड़कर सभी डुप्लिकेट पंक्तियां हटाएं?

  5. क्लाउड एसक्यूएल प्रॉक्सी का उपयोग कर एकाधिक क्लाउडएसक्यूएल इंस्टेंस से कनेक्ट करना?