gpt4 book ai didi

java - Spring 命名参数异常

转载 作者:行者123 更新时间:2023-11-30 06:11:41 25 4
gpt4 key购买 nike

我正在尝试使用 spring JdbcTemplate 中的命名参数在数据库中插入值。我正在对 NamedParameter 使用 setter 注入(inject),但它显示异常。如果我使用构造函数注入(inject)那么它会工作正常。我不知道我在哪里做错了有人帮我解决这个问题

代码

员工.java

public class Employee {
String name,pwd;
int en;

public Employee(String name,String pwd,int en){
this.en=en;
this.name=name;
this.pwd=pwd;
}

public String getName(){
return name;
}

public void setName(String name){
this.name=name;
}

public String getPwd(){
return pwd;
}
public void setPwd(String pwd){
this.pwd=pwd;
}

public int getEn(){
return en;
}

public void setEn(int en){
this.en=en;
}

}

EmployeeDao.java

import java.sql.*;

import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.PreparedStatementCallback;
import org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate;

import java.util.*;

import org.springframework.dao.DataAccessException;

public class EmployeeDao {

NamedParameterJdbcTemplate template;

public void setTemplate(NamedParameterJdbcTemplate template){
this.template=template;
}

public void save(Employee emp){
String q="insert into users values(:name,:pwd,:en)";
Map<String, Object> m=new HashMap<String, Object>();
m.put("name",emp.getName());
m.put("pwd",emp.getPwd());
m.put("en",emp.getEn());

template.execute(q,m,new PreparedStatementCallback() {

public Object doInPreparedStatement(PreparedStatement ps) throws SQLException,DataAccessException{
return ps.executeUpdate();
}

});
}

}

测试.java

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class Test {

public static void main(String args[]){
ApplicationContext ctx=new ClassPathXmlApplicationContext("applicationcontext.xml");

EmployeeDao emp=(EmployeeDao)ctx.getBean("s");
emp.save(new Employee("vijay","perfect",123));
}

}

applicationcontext.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans
xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:p="http://www.springframework.org/schema/p"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">

<bean id="ds" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/LoginTrack"/>
<property name="username" value="root" />
<property name="password" value=""/>
</bean>

<bean id="jtemplate" class="org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate">
<property name="dataSource" ref="ds"/>
</bean>
<bean id="s" class="EmployeeDao">
<property name="template" ref="jtemplate"/>
</bean>
</beans>

堆栈跟踪:

log4j:WARN No appenders could be found for logger (org.springframework.core.env.StandardEnvironment).
log4j:WARN Please initialize the log4j system properly.
Exception in thread "main" org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'jtemplate' defined in class path resource [applicationcontext.xml]: Instantiation of bean failed; nested exception is org.springframework.beans.BeanInstantiationException: Could not instantiate bean class [org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate]: No default constructor found; nested exception is java.lang.NoSuchMethodException: org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate.<init>()
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateBean(AbstractAutowireCapableBeanFactory.java:1013)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:959)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:490)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:461)
at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:295)
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:223)
at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:292)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:194)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:626)
at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:932)
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:479)
at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:139)
at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:83)
at Test.main(Test.java:6)
Caused by: org.springframework.beans.BeanInstantiationException: Could not instantiate bean class [org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate]: No default constructor found; nested exception is java.lang.NoSuchMethodException: org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate.<init>()
at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:83)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateBean(AbstractAutowireCapableBeanFactory.java:1006)
... 13 more
Caused by: java.lang.NoSuchMethodException: org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate.<init>()
at java.lang.Class.getConstructor0(Class.java:2892)
at java.lang.Class.getDeclaredConstructor(Class.java:2058)
at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:78)
... 14 more

最佳答案

它给出错误是因为您正在使用默认构造函数为 NamedParameterJdbcTemplate 创建 bean 并且它不可用。

将您的 bean 定义修改为:

<bean id="jtemplate" class="org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate">
<constructor-arg ref="ds"/>
</bean>

希望对你有帮助

关于java - Spring 命名参数异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33819306/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com