为提高效率,提问时请提供以下信息,问题描述清晰可优先响应。
【DM版本】: dm8_20221128_x86_win64
【操作系统】:windows11
【CPU】:
【问题描述】*:
spring + spring-data-jpa 项目打成war包, 部署到 AAMS-V10 敏捷版,
其中 jar包依赖有:
<dependency>
<groupId>com.dameng</groupId>
<artifactId>DmJdbcDriver18</artifactId>
<version>8.1.2.192</version>
</dependency>
<dependency>
<groupId>com.dameng</groupId>
<artifactId>DmDialect-for-hibernate4.0</artifactId>
<version>8.1.2.141</version>
</dependency>
jdbc配置有(客户端网络通、有ITSM模式、登陆能查看数据):
jdbc.driver=dm.jdbc.driver.DmDriver
jdbc.url=jdbc:dm://10.3.15.14:5236
jdbc.username=ITSM
jdbc.password=Jtwmy@dt4gx
启动后报错:
Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name ‘hibernateJpaVendorAdapter’ defined in file [/Users/chyzhong/01-worktools/30-AAMS-V10/webapps/ITSM/WEB-INF/classes/applicationContext.xml]: Cannot create inner bean ‘org.springside.modules.persistence.Hibernates#5a398965’ of type [org.springside.modules.persistence.Hibernates] while setting bean property ‘databasePlatform’; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name ‘org.springside.modules.persistence.Hibernates#5a398965’ defined in file [/Users/chyzhong/01-worktools/30-AAMS-V10/webapps/ITSM/WEB-INF/classes/applicationContext.xml]: Instantiation of bean failed; nested exception is org.springframework.beans.factory.BeanDefinitionStoreException: Factory method [public static java.lang.String org.springside.modules.persistence.Hibernates.getDialect(javax.sql.DataSource)] threw exception; nested exception is java.lang.IllegalArgumentException: Unknown Database of jdbc:dm://10.3.15.14:5236
at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveInnerBean(BeanDefinitionValueResolver.java:281)
at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveValueIfNecessary(BeanDefinitionValueResolver.java:120)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyPropertyValues(AbstractAutowireCapableBeanFactory.java:1360)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1118)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:517)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:456)
at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:294)
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:225)
at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:291)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:193)
at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveReference(BeanDefinitionValueResolver.java:322)
… 69 more
Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name ‘org.springside.modules.persistence.Hibernates#5a398965’ defined in file [/Users/chyzhong/01-worktools/30-AAMS-V10/webapps/ITSM/WEB-INF/classes/applicationContext.xml]: Instantiation of bean failed; nested exception is org.springframework.beans.factory.BeanDefinitionStoreException: Factory method [public static java.lang.String org.springside.modules.persistence.Hibernates.getDialect(javax.sql.DataSource)] threw exception; nested exception is java.lang.IllegalArgumentException: Unknown Database of jdbc:dm://10.3.15.14:5236
at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:581)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1015)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:911)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:485)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:456)
at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveInnerBean(BeanDefinitionValueResolver.java:270)
… 79 more
Caused by: org.springframework.beans.factory.BeanDefinitionStoreException: Factory method [public static java.lang.String org.springside.modules.persistence.Hibernates.getDialect(javax.sql.DataSource)] threw exception; nested exception is java.lang.IllegalArgumentException: Unknown Database of jdbc:dm://10.3.15.14:5236
at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:169)
at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:570)
… 84 more
Caused by: java.lang.IllegalArgumentException: Unknown Database of jdbc:dm://10.3.15.14:5236
at org.springside.modules.persistence.Hibernates.getDialect(Hibernates.java:60)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:149)
… 85 more
可以打印下达梦的jdbc日志发来看下
您查一下引用url的变量,把这个url连接串作为数据库名传入了