java - Unable to get JDBC connection in Spring application to MySQL -


मैंने स्प्रिंग में डीबी कॉन्फ़िगरेशन का पालन किया है:

  & lt; bean id = "dataSource" Class = "org.apache.commons.dbcp.BasicDataSource" नष्ट-विधि = "बंद" & gt; & Lt; प्रॉपर्टी नाम = "url" मान = "jdbc: dburl" / & gt; & Lt; संपत्ति नाम = "driverClassName" मान = "com.mysql.jdbc.Driver" / & gt; & Lt; संपत्ति नाम = "उपयोगकर्ता नाम" मान = "उपयोगकर्ता नाम" / & gt; & Lt; संपत्ति नाम = "पासवर्ड" मान = "पासवॉर्फ" / & gt; & Lt; प्रॉपर्टी नाम = "हटाए गए हटाए गए" मान = "सही" / & gt; & Lt; गुण नाम = "प्रारंभिक आकार" मान = "3" / & gt; & Lt; संपत्ति नाम = "अधिकतमअक्टिव" मान = "5" / & gt; & Lt; / सेम ​​& gt;   

डीबी से गुण मूल्यों को लोड करने के लिए अतिरिक्त कॉन्फ़िगरेशन।

  & lt; bean id = "config1" class = "org.apache.commons.configuration.DatabaseConfiguration "& gt; & Lt; constructor-arg प्रकार = "javax.sql.DataSource" रेफरी = "डेटा स्रोत" / & gt; & Lt; कन्स्ट्रक्टर- आर्ग सूचकांक = "1" मान = "tablename1" / & gt; & Lt; कन्स्ट्रक्टर- आर्ग सूचकांक = "2" मान = "स्तंभ नाम" / & gt; & Lt; कन्स्ट्रक्टर- आर्ग सूचक = "3" मान = "स्तंभमान" / & gt; & Lt; / सेम ​​& gt; & Lt; बीन आईडी = "configFactory1" वर्ग = "org.springmodules.commons.configuration.CommonsConfigurationFactoryBean" & gt; & Lt; constructor-arg रेफरी = "config1" / & gt; & Lt; / सेम ​​& gt; & Lt;! - डीबी गुण प्रारंभिक - & gt; & Lt; बीन आईडी = "कॉन्फ़िगरेशन प्लेसहॉल्डर 1" वर्ग = "org.springframework.beans.factory.config.PropertyPlaceholderConfigurer" & gt; & Lt; प्रॉपर्टी नाम = "अनदेखा UnlessolvablePlaceholders" मान = "गलत" / & gt; & Lt; प्रॉपर्टी नाम = "प्रॉपर्टी" ref = "configFactory1" / & gt; & Lt; / सेम ​​& gt; & Lt; बीन आईडी = "config2" class = "org.apache.commons.configuration.DatabaseConfiguration" & gt; & Lt; constructor-arg प्रकार = "javax.sql.DataSource" रेफरी = "डेटा स्रोत" / & gt; & Lt; कन्स्ट्रक्टर- आर्ग सूचक = "1" मान = "tablename2" / & gt; & Lt; कन्स्ट्रक्टर- आर्ग सूचकांक = "2" मान = "स्तंभ नाम" / & gt; & Lt; कन्स्ट्रक्टर- आर्ग सूचक = "3" मान = "स्तंभमान" / & gt; & Lt; / सेम ​​& gt; & Lt; बीन आईडी = "configFactory2" वर्ग = "org.springmodules.commons.configuration.CommonsConfigurationFactoryBean" & gt; & Lt; constructor-arg रेफरी = "config2" / & gt; & Lt; / सेम ​​& gt; & Lt;! - डीबी गुण प्रारंभिक - & gt; & Lt; बीन आईडी = "कॉन्फ़िगरेशन प्लेसहॉल्डर 2" वर्ग = "org.springframework.beans.factory.config.PropertyPlaceholderConfigurer" & gt; & Lt; प्रॉपर्टी नाम = "अनदेखा UnlessolvablePlaceholders" मान = "गलत" / & gt; & Lt; संपत्ति का नाम = "गुण" रिफ = "कॉन्फ़िफिचर 2" / & gt; & Lt; / सेम ​​& gt;   

डीएओ कॉन्फ़िगरेशन जो समस्या देता है:

  & lt;! - डीएओ बीन जो समस्या पैदा कर रहा है - & gt; & Lt; बीन आईडी = "समस्याग्रस्त बीन" वर्ग = "com.example.ProblematicDAOImpl" स्कोप = "सिंगलटन" & gt; & Lt; संपत्ति नाम = "डेटा स्रोत" रिफ = "डेटा स्रोत" / & gt; & Lt; / सेम ​​& gt;   

जब मैं आवेदन प्रारंभ करता हूँ, तो मैं निम्नलिखित पंक्ति में फंस जाता हूं:

  17 फरवरी 2014 15: 39: 58,981 - मुख्य - डेटाबेस - org.springframework Jdbc.core.JdbcTemplate.query (JdbcTemplate.java:691) - तैयार एसक्यूएल क्वेरी निष्पादित 17 फरवरी 2014 15: 39: 58,983 - मुख्य - DEBUG - org.springframework.jdbc.core.JdbcTemplate.execute (JdbcTemplate.java:625) - तैयार एसक्यूएल स्टेटमेंट निष्पादित [एसक्यूएल स्टेटमेंट] 17 फरवरी 2014 15: 39: 59,000 - मुख्य - डिबग - org.springframework.jdbc.datasource.DataSourceUtils.doGetConnection (डेटा स्रोत यूटीली। Java:110) - डेटासॉर्स से जेडीबीसी कनेक्शन प्राप्त करना   

इस लाइन के बाद, आवेदन लटका हुआ है और जवाब नहीं देता। यह या तो अपवाद नहीं फेंकता है

मैंने निम्नलिखित चेक किए हैं:

  • बढ़ी अधिकतम एक्टिव मान।
  • बढ़ी initialsize मूल्य।
  • चेक किया गया - एसक्यूएल स्टेटमेंट को क्वेरी ब्राउज़र में निष्पादित किया जा रहा है।

    ** UPDATE **

    मैं आगे कोड डीबग कर दिया है, कोड <लाइन> पंक्ति में 642 org.springframework.jdbc.core.JdbcTemplate org.springframework.jdbc.core.JdbcTemplate.execute (तैयार की गई स्टेटीमेंट क्रीटर, तैयार किए गए स्टाटेमेंट कॉलबैक & lt; T & gt;)

    कोड की रेखा ये हैं:

      यदि (this.nativeJdbcExtractor! = नल) {psToUse = this.nativeJdbcExtractor.getNativePreparedStatement (ps); } टी परिणाम = action.doInPreparedStatement (psToUse); // इस लाइन हैंडल पर हैंगिंग्स (पीएस); वापसी परिणाम;    

    मैं आपको मिल गया ¥ ¤ यह अपने आप को हल किया मैं किसी भी पैरामीटर के साथ एक क्वेरी कॉल करने के लिए NamedParameterJdbctemplate का उपयोग कर रहा था। यह वसंत एपीआई में तैयार वक्तव्य निष्पादित करते समय फांसी पर लटकाया गया था। मैंने इसे JdbcTempalte वर्ग में बदल दिया। यह ठीक काम करता है।

Comments

Popular posts from this blog

wpf - ControlTemplate with changes for every class -

sonata admin - how to add ManyToOne property field in configureListfield in sonataAdmin -

sql - Return Function using Cursor -