Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sql-server/27.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 名称为'的bean定义无效;数据源';在类路径资源[spring/database/DataSource.xml]中定义_Java_Sql Server_Spring_Hibernate - Fatal编程技术网

Java 名称为'的bean定义无效;数据源';在类路径资源[spring/database/DataSource.xml]中定义

Java 名称为'的bean定义无效;数据源';在类路径资源[spring/database/DataSource.xml]中定义,java,sql-server,spring,hibernate,Java,Sql Server,Spring,Hibernate,我试图创建一个应用程序,使用Spring、Maven和Hibernate访问sql server数据库。当我尝试运行应用程序时,我收到以下错误: Exception in thread "main" org.springframework.beans.factory.BeanDefinitionStoreException: Invalid bean definition with name 'dataSource' defined in class path resource [spring/

我试图创建一个应用程序,使用Spring、Maven和Hibernate访问sql server数据库。当我尝试运行应用程序时,我收到以下错误:

Exception in thread "main" org.springframework.beans.factory.BeanDefinitionStoreException: Invalid bean definition with name 'dataSource' defined in class path resource [spring/database/DataSource.xml]: Could not resolve placeholder 'jdbc.driverClassName'
这是我的课

DataSoucre.xml

<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">

<bean 
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="location">
    <value>/properties/database.properties</value>
</property>
</bean>

<bean id="dataSource" 
     class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="${jdbc.driverClassName}" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
</bean>

</beans>
(我在这里屏蔽了用户名和密码),我也有一个BeanLocation.xml,但不应该真的需要发布它

有人知道怎么解决这个问题吗?这让我发疯了!
感谢您在XML中使用
${database.driverClassName}
,而不是
${jdbc.driverClassName}
,即
数据库.properties
文件中使用的属性的名称。

首先需要确保配置文件的根位置可以在类路径下访问,然后,添加属性文件的相对路径,例如。 classpath:properties/database.properties

database.driverClassName=net.sourceforge.jtds.jdbc.Driver
database.url=jdbc:jtds:sqlserver://localhost:1433;databaseName=Customer
database.username=*****
database.password=*****

就我而言,一个额外的问题是一个额外的问题“'错误地出现,导致了这一错误。希望这有帮助。

我认为问题出在您的属性文件位置。你是否有类路径根文件夹属性和数据库内的.properties属性?很好,这就成功了…我会标记它,但还没有足够的代表来标记它:/谢谢
database.driverClassName=net.sourceforge.jtds.jdbc.Driver
database.url=jdbc:jtds:sqlserver://localhost:1433;databaseName=Customer
database.username=*****
database.password=*****