草庐IT

java - Jdbc 的 Spring Beans 不工作

coder 2024-03-13 原文

我昨晚花了很多时间试图解决这个问题。我有一个正在运行的 HSQLDB 服务器,我可以使用 JDBC 驱动程序连接到它。作业的下一部分是做同样的事情,但使用 Spring 框架。我声明了我的 bean,创建了我的 DAO 类,但程序没有连接到服务器。因为这是我们第一次使用 JdbcTemplate,所以我们不应该进行 Autowiring 。这是我的文件:

JdbcUserDAO

public class JdbcUserDAO extends JdbcDaoSupport
                    implements UserDAO {

    public User getUserWithId(int id) {
        return new User(1,"gamda","test");
    }

    public int howManyUsers() {
        JdbcTemplate test = getJdbcTemplate();
        System.out.println("Got template");

        try {
            getConnection();
            System.out.println("Got connection");   
        } catch (Exception e) {
            System.out.println("Not connecting");
        }


        int result = test.queryForInt("select count from users");
        System.out.println("Query success");
        return result;
    }

}

beans.xml(与我的 .java 文件在同一个文件夹中,如果有区别的话)

<?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="userDAO" class="com.project2.db.JdbcUserDAO">
        <property name="dataSource" ref="dataSource"/>
    </bean>

    <bean id="questionDAO" class="com.project2.db.JdbcQuestionDAO">
        <property name="jdbcTemplate" ref="jdbcTemplate"/>
    </bean>

    <bean id="answerDAO" class="com.project2.db.AnswerDAO">
        <property name="jdbcTemplate" ref="jdbcTemplate"/>
    </bean>

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

    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" 
    destroy-method="close">
        <property name="driverClassName" value="org.hsqldb.jdbc.JDBCDriver"/>
        <property name="url" value="jdbc:hsqldb:hsql://localhost/cpsc476;ifexists=true"/>
        <property name="username" value="SA"/>
        <property name="password" value="Passw0rd"/>
    </bean>
</beans>

build.xml for ant:

<project 
    name="DB_Access" 
    default="compile" 
    xmlns:artifact="antlib:org.apache.maven.artifact.ant">

<target name="init">
    <mkdir dir="classes" />
</target>

<target name="clean">
    <delete dir="classes" />
    <delete dir="jar" />
</target>

<target name="compile" depends="init">
    <javac srcdir="src"
           destdir="classes">
        <classpath refid="dependency.classpath" />
    </javac>
</target>

<target name="run" depends="compile">
    <java classname="com.project2.db.ListQuestionsAndAnswers">
        <classpath>
            <path refid="dependency.classpath" />
            <path location="classes/" />
        </classpath>
    </java>
</target>

<target name="jar" depends="compile">
    <mkdir dir="jar" />
    <jar destfile="jar/db.jar" basedir="classes">
        <manifest>
            <attribute name="Main-Class" value="com.project2.db.dbCon" />
        </manifest>
    </jar>
</target>

<artifact:dependencies 
    pathId="dependency.classpath"
    filesetId="dependency.fileset">
    <dependency
        groupId="org.springframework"
        artifactId="spring-jdbc"
        version="3.2.4.RELEASE" />

    <dependency
        groupId="org.springframework"
        artifactId="spring-beans"
        version="3.2.4.RELEASE"/>

    <dependency
        groupId="org.springframework"
        artifactId="spring-context"
        version="3.0.2.RELEASE"/>

    <dependency
        groupId="org.hsqldb"
        artifactId="hsqldb"
        version="2.3.0" />
    <dependency
        groupId="commons-dbcp"
        artifactId="commons-dbcp"
        version="1.4" />
</artifact:dependencies>
</project>

我正在使用的测试类:阅读提供的教程后编辑

public class ListQuestionsAndAnswers {
    public static int main( String[] args ) {

        ApplicationContext appContext = new ClassPathXmlApplicationContext(
        "beans.xml");

        JdbcUserDAO test = (JdbcUserDAO) appContext.getBean("userDAO"); 
        int answer = test.howManyUsers();
        System.out.println(answer);
        return 0;
    }
}

当我执行“ant run”时,这是输出:已编辑 因为这是一个新错误

 >[java] org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'userDAO' defined in class path resource [beans.xml]: Initialization of bean failed; nested exception is java.lang.NoSuchFieldError: NULL
 >[java]    at org.apache.tools.ant.taskdefs.ExecuteJava.execute(ExecuteJava.java:194)
 >[java]    at org.apache.tools.ant.taskdefs.Java.run(Java.java:771)
 >[java]    at org.apache.tools.ant.taskdefs.Java.executeJava(Java.java:221)
 >[java]    at org.apache.tools.ant.taskdefs.Java.executeJava(Java.java:135)
 >[java]    at org.apache.tools.ant.taskdefs.Java.execute(Java.java:108)
 >[java]    at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:292)
 >[java]    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 >[java]    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
 >[java]    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 >[java]    at java.lang.reflect.Method.invoke(Method.java:606)
 >[java]    at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
 >[java]    at org.apache.tools.ant.Task.perform(Task.java:348)
 >[java]    at org.apache.tools.ant.Target.execute(Target.java:435)
 >[java]    at org.apache.tools.ant.Target.performTasks(Target.java:456)
 >[java]    at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1393)
 >[java]    at org.apache.tools.ant.Project.executeTarget(Project.java:1364)
 >[java]    at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41)
 >[java]    at org.apache.tools.ant.Project.executeTargets(Project.java:1248)
 >[java]    at org.apache.tools.ant.Main.runBuild(Main.java:851)
 >[java]    at org.apache.tools.ant.Main.startAnt(Main.java:235)
 >[java]    at org.apache.tools.ant.launch.Launcher.run(Launcher.java:280)
 >[java]    at org.apache.tools.ant.launch.Launcher.main(Launcher.java:109)
 >[java] Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'userDAO' defined in class path resource [beans.xml]: Initialization of bean failed; nested exception is java.lang.NoSuchFieldError: NULL
 >[java]    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:529)
 >[java]    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:458)
 >[java]    at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:295)
 >[java]    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:223)
 >[java]    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:292)
 >[java]    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:194)
 >[java]    at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:628)
 >[java]    at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:872)
 >[java]    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:423)
 >[java]    at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:139)
 >[java]    at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:83)
 >[java]    at com.project2.db.ListQuestionsAndAnswers.main(Unknown Source)
 >[java]    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 >[java]    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
 >[java]    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 >[java]    at java.lang.reflect.Method.invoke(Method.java:606)
 >[java]    at org.apache.tools.ant.taskdefs.ExecuteJava.run(ExecuteJava.java:217)
 >[java]    at org.apache.tools.ant.taskdefs.ExecuteJava.execute(ExecuteJava.java:152)
 >[java]    ... 21 more
 >[java] Caused by: java.lang.NoSuchFieldError: NULL
 >[java]    at org.springframework.expression.TypedValue.<clinit>(TypedValue.java:31)
 >[java]    at org.springframework.expression.spel.support.StandardEvaluationContext.setRootObject(StandardEvaluationContext.java:82)
 >[java]    at org.springframework.expression.spel.support.StandardEvaluationContext.<init>(StandardEvaluationContext.java:71)
 >[java]    at org.springframework.context.expression.StandardBeanExpressionResolver.evaluate(StandardBeanExpressionResolver.java:124)
 >[java]    at org.springframework.beans.factory.support.AbstractBeanFactory.evaluateBeanDefinitionString(AbstractBeanFactory.java:1312)
 >[java]    at org.springframework.beans.factory.support.BeanDefinitionValueResolver.evaluate(BeanDefinitionValueResolver.java:225)
 >[java]    at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveReference(BeanDefinitionValueResolver.java:312)
 >[java]    at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveValueIfNecessary(BeanDefinitionValueResolver.java:107)
 >[java]    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyPropertyValues(AbstractAutowireCapableBeanFactory.java:1387)
 >[java]    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1128)
 >[java]    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:519)
 >[java]    ... 38 more
 >[java] Java Result: -1  

所以我知道我的 JdbcTemplate 不为空,但它无法连接到数据库,我不知道如何检查连接或使其连接。

最佳答案

您已将 JdbcUserDAO 定义为 ID 为 userDAO 的 spring bean,但您正在使用 new 运算符创建它的实例,这不会照顾它的依赖

你需要初始化spring bean上下文,然后从上下文中获取bean

关于java - Jdbc 的 Spring Beans 不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19432497/

有关java - Jdbc 的 Spring Beans 不工作的更多相关文章

  1. ruby-on-rails - 由于 "wkhtmltopdf",PDFKIT 显然无法正常工作 - 2

    我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-

  2. ruby-on-rails - 'compass watch' 是如何工作的/它是如何与 rails 一起使用的 - 2

    我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t

  3. ruby - 无法让 RSpec 工作—— 'require' : cannot load such file - 2

    我花了三天的时间用头撞墙,试图弄清楚为什么简单的“rake”不能通过我的规范文件。如果您遇到这种情况:任何文件夹路径中都不要有空格!。严重地。事实上,从现在开始,您命名的任何内容都没有空格。这是我的控制台输出:(在/Users/*****/Desktop/LearningRuby/learn_ruby)$rake/Users/*******/Desktop/LearningRuby/learn_ruby/00_hello/hello_spec.rb:116:in`require':cannotloadsuchfile--hello(LoadError) 最佳

  4. java - 等价于 Java 中的 Ruby Hash - 2

    我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/

  5. ruby-on-rails - rspec should have_select ('cars' , :options => ['volvo' , 'saab' ] 不工作 - 2

    关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion在首页我有:汽车:VolvoSaabMercedesAudistatic_pages_spec.rb中的测试代码:it"shouldhavetherightselect"dovisithome_pathit{shouldhave_select('cars',:options=>['volvo','saab','mercedes','audi'])}end响应是rspec./spec/request

  6. ruby-on-rails - s3_direct_upload 在生产服务器中不工作 - 2

    在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo

  7. java - 从 JRuby 调用 Java 类的问题 - 2

    我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www

  8. ruby - JetBrains RubyMine 3.2.4 调试器不工作 - 2

    使用Ruby1.9.2运行IDE提示说需要gemruby​​-debug-base19x并提供安装它。但是,在尝试安装它时会显示消息Failedtoinstallgems.Followinggemswerenotinstalled:C:/ProgramFiles(x86)/JetBrains/RubyMine3.2.4/rb/gems/ruby-debug-base19x-0.11.30.pre2.gem:Errorinstallingruby-debug-base19x-0.11.30.pre2.gem:The'linecache19'nativegemrequiresinstall

  9. java - 我的模型类或其他类中应该有逻辑吗 - 2

    我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我

  10. java - 什么相当于 ruby​​ 的 rack 或 python 的 Java wsgi? - 2

    什么是ruby​​的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht

随机推荐