हाइबरनेट - कॉन्फ़िगरेशन
हाइबरनेट को पहले से जानना आवश्यक है - जहां मैपिंग जानकारी को खोजने के लिए जहां परिभाषित करता है कि आपके जावा कक्षाएं डेटाबेस तालिकाओं से कैसे संबंधित हैं। हाइबरनेट को डेटाबेस और अन्य संबंधित मापदंडों से संबंधित कॉन्फ़िगरेशन सेटिंग्स का एक सेट भी आवश्यक है। ऐसी सभी जानकारी आमतौर पर मानक जावा प्रॉपर्टीज़ फ़ाइल के रूप में आपूर्ति की जाती हैhibernate.properties, या एक XML फ़ाइल के रूप में नाम दिया गया है hibernate.cfg.xml।
मैं XML स्वरूपित फ़ाइल पर विचार करूंगा hibernate.cfg.xmlमेरे उदाहरणों में आवश्यक हाइबरनेट गुण निर्दिष्ट करने के लिए। अधिकांश गुण अपने डिफ़ॉल्ट मान लेते हैं और उन्हें संपत्ति फ़ाइल में निर्दिष्ट करने की आवश्यकता नहीं होती है जब तक कि वास्तव में इसकी आवश्यकता न हो। यह फ़ाइल आपके एप्लिकेशन के क्लासपाथ के रूट डायरेक्टरी में रखी गई है।
हाइबरनेट गुण
निम्नलिखित महत्वपूर्ण गुणों की सूची है, आपको एक स्टैंडअलोन स्थिति में डेटाबेस के लिए कॉन्फ़िगर करने की आवश्यकता होगी -
अनु क्रमांक। | गुण और विवरण |
---|---|
1 | hibernate.dialect यह गुण हाइबरनेट को चुने हुए डेटाबेस के लिए उपयुक्त SQL उत्पन्न करता है। |
2 | hibernate.connection.driver_class JDBC ड्राइवर वर्ग। |
3 | hibernate.connection.url डेटाबेस उदाहरण के लिए JDBC URL। |
4 | hibernate.connection.username डेटाबेस उपयोगकर्ता नाम। |
5 | hibernate.connection.password डेटाबेस पासवर्ड। |
6 | hibernate.connection.pool_size हाइबरनेट डेटाबेस कनेक्शन पूल में प्रतीक्षा कर रहे कनेक्शन की संख्या को सीमित करता है। |
7 | hibernate.connection.autocommit JDBC कनेक्शन के लिए ऑटोकॉमिट मोड का उपयोग करने की अनुमति देता है। |
यदि आप एक एप्लिकेशन सर्वर और JNDI के साथ एक डेटाबेस का उपयोग कर रहे हैं, तो आपको निम्नलिखित गुणों को कॉन्फ़िगर करना होगा -
अनु क्रमांक। | गुण और विवरण |
---|---|
1 | hibernate.connection.datasource JNDI नाम एप्लिकेशन सर्वर संदर्भ में परिभाषित किया गया है, जिसे आप एप्लिकेशन के लिए उपयोग कर रहे हैं। |
2 | hibernate.jndi.class जेएनडीआई के लिए द इनिशिएटिवकॉन्टेक्ट क्लास। |
3 | hibernate.jndi.<JNDIpropertyname> किसी भी JNDI संपत्ति JNDI को आप की तरह गुजरता है InitialContext । |
4 | hibernate.jndi.url JNDI के लिए URL प्रदान करता है। |
5 | hibernate.connection.username डेटाबेस उपयोगकर्ता नाम। |
6 | hibernate.connection.password डेटाबेस पासवर्ड। |
MySQL डाटाबेस के साथ हाइबरनेट करें
MySQL आज उपलब्ध सबसे लोकप्रिय ओपन-सोर्स डेटाबेस सिस्टम में से एक है। हमें बनाने दोhibernate.cfg.xmlकॉन्फ़िगरेशन फ़ाइल और इसे अपने एप्लिकेशन के क्लासपाथ की जड़ में रखें। आपको यह सुनिश्चित करना होगा कि आपके पास हैtestdb डेटाबेस आपके MySQL डेटाबेस में उपलब्ध है और आपके पास एक उपयोगकर्ता है test डेटाबेस का उपयोग करने के लिए उपलब्ध है।
XML कॉन्फ़िगरेशन फ़ाइल को हाइबरनेट 3 कॉन्फ़िगरेशन DTD के अनुरूप होना चाहिए, जो यहां उपलब्ध है http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd।
<?xml version = "1.0" encoding = "utf-8"?>
<!DOCTYPE hibernate-configuration SYSTEM
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<property name = "hibernate.dialect">
org.hibernate.dialect.MySQLDialect
</property>
<property name = "hibernate.connection.driver_class">
com.mysql.jdbc.Driver
</property>
<!-- Assume test is the database name -->
<property name = "hibernate.connection.url">
jdbc:mysql://localhost/test
</property>
<property name = "hibernate.connection.username">
root
</property>
<property name = "hibernate.connection.password">
root123
</property>
<!-- List of XML mapping files -->
<mapping resource = "Employee.hbm.xml"/>
</session-factory>
</hibernate-configuration>
उपरोक्त कॉन्फ़िगरेशन फ़ाइल शामिल है <mapping> टैग, जो कि हाइबरनेट मैपिंग फ़ाइल से संबंधित हैं और हम अगले अध्याय में देखेंगे कि वास्तव में हाइबरनेट मैपिंग फ़ाइल क्या है और हम इसका उपयोग कैसे और क्यों करते हैं?
निम्नलिखित विभिन्न महत्वपूर्ण डेटाबेस बोली संपत्ति प्रकार की सूची है -
अनु क्रमांक। | डेटाबेस और बोली संपत्ति |
---|---|
1 | DB2 org.hibernate.dialect.DB2Dialect |
2 | HSQLDB org.hibernate.dialect.HSQLDialect |
3 | HypersonicSQL org.hibernate.dialect.HSQLDialect |
4 | Informix org.hibernate.dialect.InformixDialect |
5 | Ingres org.hibernate.dialect.IngresDialect |
6 | Interbase org.hibernate.dialect.InterbaseDialect |
7 | Microsoft SQL Server 2000 org.hibernate.dialect.SQLServerDialect |
8 | Microsoft SQL Server 2005 org.hibernate.dialect.SQLServer2005Dialect |
9 | Microsoft SQL Server 2008 org.hibernate.dialect.SQLServer2008Dialect |
10 | MySQL org.hibernate.dialect.MySQLDialect |
1 1 | Oracle (any version) org.hibernate.dialect.OracleDialect |
12 | Oracle 11g org.hibernate.dialect.Oracle10gDialect |
13 | Oracle 10g org.hibernate.dialect.Oracle10gDialect |
14 | Oracle 9i org.hibernate.dialect.Oracle9iDialect |
15 | PostgreSQL org.hibernate.dialect.PostgreSQLDialect |
16 | Progress org.hibernate.dialect.ProgressDialect |
17 | SAP DB org.hibernate.dialect.SAPDBDialect |
18 | Sybase org.hibernate.dialect.SybaseDialect |
19 | Sybase Anywhere org.hibernate.dialect.SybaseAnywhereDialect |