JDBC - डेटा प्रकार

JDBC ड्राइवर डेटाबेस में भेजने से पहले जावा डेटा प्रकार को उपयुक्त JDBC प्रकार में परिवर्तित करता है। यह अधिकांश डेटा प्रकारों के लिए एक डिफ़ॉल्ट मैपिंग का उपयोग करता है। उदाहरण के लिए, एक Java int SQL INTEGER में बदल जाता है। ड्राइवरों के बीच स्थिरता प्रदान करने के लिए डिफ़ॉल्ट मैपिंग बनाई गई थी।

निम्न तालिका डिफ़ॉल्ट JDBC डेटा प्रकार को बताती है जिसे जावा डेटा प्रकार में कनवर्ट किया जाता है, जब आप SetXXX () विधि की तैयारी या कॉलटेस्टलेट ऑब्जेक्ट या ResultSet.updatexX () विधि को कॉल करते हैं।

एसक्यूएल JDBC / जावा setXXX updateXXX
VARCHAR java.lang.String setString updateString
CHAR java.lang.String setString updateString
LONGVARCHAR java.lang.String setString updateString
बीआईटी बूलियन setBoolean updateBoolean
संख्यात्मक java.math.BigDecimal setBigDecimal updateBigDecimal
TINYINT बाइट setByte updateByte
SMALLINT कम setShort updateShort
पूर्णांक पूर्णांक setInt updateInt
BIGINT लंबा setLong updateLong
असली नाव setFloat updateFloat
फ्लोट नाव setFloat updateFloat
दोहरा दोहरा setDouble updateDouble
VARBINARY बाइट [] setBytes updateBytes
बायनरी बाइट [] setBytes updateBytes
दिनांक java.sql.Date तारीख सेट करें डेट अपडेट करें
समय java.sql.Time निर्धारित समय समय सुधारें
TIMESTAMP java.sql.Timestamp setTimestamp updateTimestamp
CLOB java.sql.Clob setClob updateClob
ब्लॉब java.sql.Blob setBlob updateBlob
सरणी java.sql.Array setARRAY updateARRAY
संदर्भ java.sql.Ref SetRef updateRef
struct java.sql.Struct SetStruct updateStruct

JDBC 3.0 ने BLOB, CLOB, ARRAY और REF डेटा प्रकारों के लिए समर्थन बढ़ाया है। ResultSet ऑब्जेक्ट में अब updateBLOB (), updateCLOB (), updateArray (), और updateRef () तरीके हैं जो आपको सर्वर पर संबंधित डेटा को सीधे हेरफेर करने में सक्षम करते हैं।

सेटएक्सएक्सएक्सएक्स () और अपडेटएक्सएक्सएक्सएक्सएक्स () विधियाँ आपको विशिष्ट जावा प्रकार को विशिष्ट जेडीबीसी डेटा प्रकारों में बदलने में सक्षम बनाती हैं। तरीकों, setObject () और updateObject (), आपको JDBC डेटा प्रकार के लगभग किसी भी जावा प्रकार को मैप करने में सक्षम करते हैं।

ResultSet ऑब्जेक्ट स्तंभ मान को प्राप्त करने के लिए प्रत्येक डेटा प्रकार के लिए इसी getXXX () विधि प्रदान करता है। प्रत्येक विधि का उपयोग स्तंभ नाम के साथ या इसकी क्रमिक स्थिति से किया जा सकता है।

एसक्यूएल JDBC / जावा setXXX getXXX
VARCHAR java.lang.String setString GetString
CHAR java.lang.String setString GetString
LONGVARCHAR java.lang.String setString GetString
बीआईटी बूलियन setBoolean getBoolean
संख्यात्मक java.math.BigDecimal setBigDecimal getBigDecimal
TINYINT बाइट setByte getByte
SMALLINT कम setShort getShort
पूर्णांक पूर्णांक setInt getInt
BIGINT लंबा setLong लंबा समय लें
असली नाव setFloat getFloat
फ्लोट नाव setFloat getFloat
दोहरा दोहरा setDouble getDouble
VARBINARY बाइट [] setBytes getBytes
बायनरी बाइट [] setBytes getBytes
दिनांक java.sql.Date तारीख सेट करें तारीख लें
समय java.sql.Time निर्धारित समय समय निकालो
TIMESTAMP java.sql.Timestamp setTimestamp getTimestamp
CLOB java.sql.Clob setClob getClob
ब्लॉब java.sql.Blob setBlob getBlob
सरणी java.sql.Array setARRAY getARRAY
संदर्भ java.sql.Ref SetRef getRef
struct java.sql.Struct SetStruct getStruct

दिनांक और समय डेटा प्रकार

SQL DATE प्रकार के java.sql.Date क्लास मैप्स, और java.sql.Time और java.sql.Timestamp क्लास मैप्स को क्रमशः SQL टाइम और SQL TIMESTAMP डेटा प्रकारों में मैप करते हैं।

निम्न उदाहरण से पता चलता है कि दिनांक और समय कक्षाएं SQL डेटा प्रकार की आवश्यकताओं से मेल खाने के लिए मानक जावा तिथि और समय मानों को कैसे प्रारूपित करती हैं।

import java.sql.Date;
import java.sql.Time;
import java.sql.Timestamp;
import java.util.*;

public class SqlDateTime {
   public static void main(String[] args) {
      //Get standard date and time
      java.util.Date javaDate = new java.util.Date();
      long javaTime = javaDate.getTime();
      System.out.println("The Java Date is:" + 
             javaDate.toString());

      //Get and display SQL DATE
      java.sql.Date sqlDate = new java.sql.Date(javaTime);
      System.out.println("The SQL DATE is: " + 
             sqlDate.toString());

      //Get and display SQL TIME
      java.sql.Time sqlTime = new java.sql.Time(javaTime);
      System.out.println("The SQL TIME is: " + 
             sqlTime.toString());
      //Get and display SQL TIMESTAMP
      java.sql.Timestamp sqlTimestamp =
      new java.sql.Timestamp(javaTime);
      System.out.println("The SQL TIMESTAMP is: " + 
             sqlTimestamp.toString());
     }//end main
}//end SqlDateTime

अब हम उपरोक्त उदाहरण को संकलित करते हैं -

C:\>javac SqlDateTime.java
C:\>

जब तुम दौड़ते हो JDBCExample, यह निम्नलिखित परिणाम उत्पन्न करता है -

C:\>java SqlDateTime
The Java Date is:Tue Aug 18 13:46:02 GMT+04:00 2009
The SQL DATE is: 2009-08-18
The SQL TIME is: 13:46:02
The SQL TIMESTAMP is: 2009-08-18 13:46:02.828
C:\>

पूर्ण मूल्यों को संभालना

SQL का NULL मानों का उपयोग और जावा का null का उपयोग विभिन्न अवधारणाएँ हैं। तो, जावा में SQL NULL मान को संभालने के लिए, तीन रणनीति हैं जिनका आप उपयोग कर सकते हैं -

  • गेटएक्सएक्सएक्सएक्स () विधियों का उपयोग करने से बचें जो आदिम डेटा प्रकारों को वापस करते हैं।

  • आदिम डेटा प्रकारों के लिए रैपर क्लासेस का उपयोग करें, और यह जांचने के लिए ResultSet ऑब्जेक्ट का wasNull () विधि का उपयोग करें कि क्या गेटएक्सएक्सएक्सएक्सएक्स () विधि द्वारा लौटाए गए मूल्य को प्राप्त करने वाले रैपर क्लास वेरिएबल को सेट किया जाना चाहिए।

  • आदिम डेटा प्रकारों का उपयोग करें और ResultSet ऑब्जेक्ट की wasNull () विधि का परीक्षण करने के लिए कि क्या आदिम चर जो getXXX द्वारा लौटाया गया मान प्राप्त करता है (विधि) एक स्वीकार्य मूल्य पर सेट किया जाना चाहिए जिसे आपने NULL का प्रतिनिधित्व करने के लिए चुना है।

NULL मान को संभालने के लिए यहां एक उदाहरण है -

Statement stmt = conn.createStatement( );
String sql = "SELECT id, first, last, age FROM Employees";
ResultSet rs = stmt.executeQuery(sql);

int id = rs.getInt(1);
if( rs.wasNull( ) ) {
   id = 0;
}