hibernate---java.lang.UnsupportedOperationException: The user must supply a JDBC connection

來源:互聯網
上載者:User

標籤:hibernate

    在配置hibernate時,執行代碼時一直拋錯:

Exception in thread "main" java.lang.UnsupportedOperationException: The user must supply a JDBC connectionat org.hibernate.connection.UserSuppliedConnectionProvider.getConnection(UserSuppliedConnectionProvider.java:54)at org.hibernate.jdbc.ConnectionManager.openConnection(ConnectionManager.java:446)at org.hibernate.jdbc.ConnectionManager.getConnection(ConnectionManager.java:167)at org.hibernate.jdbc.AbstractBatcher.prepareQueryStatement(AbstractBatcher.java:161)at org.hibernate.loader.Loader.prepareQueryStatement(Loader.java:1616)at org.hibernate.loader.Loader.doQuery(Loader.java:717)at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:270)at org.hibernate.loader.Loader.loadEntity(Loader.java:1953)at org.hibernate.loader.entity.AbstractEntityLoader.load(AbstractEntityLoader.java:86)at org.hibernate.loader.entity.AbstractEntityLoader.load(AbstractEntityLoader.java:76)at org.hibernate.persister.entity.AbstractEntityPersister.load(AbstractEntityPersister.java:3270)at org.hibernate.event.def.DefaultLoadEventListener.loadFromDatasource(DefaultLoadEventListener.java:496)at org.hibernate.event.def.DefaultLoadEventListener.doLoad(DefaultLoadEventListener.java:477)at org.hibernate.event.def.DefaultLoadEventListener.load(DefaultLoadEventListener.java:227)at org.hibernate.event.def.DefaultLoadEventListener.proxyOrLoad(DefaultLoadEventListener.java:285)at org.hibernate.event.def.DefaultLoadEventListener.onLoad(DefaultLoadEventListener.java:152)at org.hibernate.impl.SessionImpl.fireLoad(SessionImpl.java:1080)at org.hibernate.impl.SessionImpl.get(SessionImpl.java:997)at org.hibernate.impl.SessionImpl.get(SessionImpl.java:990)at com.ado.test.hibernate.HibernateTest.main(HibernateTest.java:25)

    後來看了背景源碼,發現建立的ConnectionProvider執行個體為UserSuppliedConnectionProvider(使用者自訂的Provider),配置有點異常。斷點跟蹤了建立該執行個體的代碼,原來是因為在根據各個配置屬性建立該執行個體時,因為配置屬性關鍵字與hibernate關鍵字不一樣,所以導致建立了使用者自訂的Provider,從而出現了上面的異常。

    測試代碼使用的是hibernate 3.5.6,標準的關鍵字可以查看org.hibernate.cfg.Environment類中的定義。hibernate版本不一樣,使用的關鍵字也不一樣。這點需要注意。

    hibernate 3.5.6使用的是:

hibernate.connection.driver_classhibernate.connection.urlhibernate.connection.usernamehibernate.connection.password




hibernate---java.lang.UnsupportedOperationException: The user must supply a JDBC connection

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.