gpt4 book ai didi

java - 线程中的异常 "main"java.lang.ClassCastException : org. springframework.jdbc.datasource.DriverManagerDataSource 无法转换

转载 作者:行者123 更新时间:2023-12-01 00:41:15 25 4
gpt4 key购买 nike

我正在尝试使用 jdbc 模板将数据插入数据库。我在 mysql 数据库中使用数据库 frr,下面的问题是我编写的代码,但出现以下错误:

Exception in thread "main" java.lang.ClassCastException: org.springframework.jdbc.datasource.DriverManagerDataSource cannot be cast to sql.sql.App
at sql.sql.App.main(App.java:25)

App.java 文件:

package sql.sql;

import java.sql.ResultSet;
import java.sql.SQLException;

import java.util.List;

import javax.sql.DataSource;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.jdbc.core.JdbcTemplate;


public class App
{
public static void main( String[] args )
{
ApplicationContext context =
new ClassPathXmlApplicationContext("web.xml");
App obj = (App) context.getBean("dataSource");
JdbcTemplate jdbcTemplateObject = new JdbcTemplate();
String SQL = "insert into issues(issue,status,comment) values (?, ?, ?)";
jdbcTemplateObject.update( SQL, new Object[]{"Zara", "test", "123"} );
System.out.println( "Hello World!" );
}
}

网络.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"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">

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

</beans>

pom.xml 文件:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>

<groupId>sql</groupId>
<artifactId>sql</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>

<name>sql</name>
<url>http://maven.apache.org</url>

<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>

<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>

<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring</artifactId>
<version>2.5.6</version>
</dependency>


<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.9</version>
</dependency>

</dependencies>
</project>

最佳答案

您的代码有很多问题。

首先是一个DriverManagerDataSourceDataSource 不是您的 App 类的实例。 (我建议用谷歌搜索一下类继承)。

DataSource ds = context.getBean("dataSource", DataSource.class);

其次,如果这是固定的,您的代码将在构建 JdbcTemplate 时失败。或者在执行查询时,因为 JdbcTemplate 需要 DataSource 它不能凭空运行。

JdbcTemplate jdbcTemplateObject = new JdbcTemplate(ds);

不过,我确实建议您将 JdbcTemplate 添加到您的配置中并检索它,而不是 DataSource

<?xml version="1.0" encoding="UTF-8"?>
<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.xsd">

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

<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource" />
</bean>

</beans>

然后将您的主要代码更改为以下内容。

public class App {

public static void main( String[] args ) {

ApplicationContext context = new ClassPathXmlApplicationContext("web.xml");
JdbcTemplate jdbcTemplateObject = context.getBean(JdbcTemplate.class);
String SQL = "insert into issues(issue,status,comment) values (?, ?, ?)";
jdbcTemplateObject.update( SQL, new Object[]{"Zara", "test", "123"} );
System.out.println( "Hello World!" );
}
}

注意:我也怀疑您的 xml 是否真的有效(或者 pom 是您正在使用的 pom)。 xml 包含对 beans 3.0 xsd 的引用,而您的 pom 使用 2.5 版本的 Spring。

关于java - 线程中的异常 "main"java.lang.ClassCastException : org. springframework.jdbc.datasource.DriverManagerDataSource 无法转换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32091647/

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