JavaEE_Mybatis_SpringMVC_整合开发奇葩问题1:dataSource报错?

来源:互联网 发布:宽带连接拨号软件 编辑:程序博客网 时间:2024/04/30 05:42

问题 DEBUG日志

DEBUG [main] - Listing file:/D:/Java_Web_Project/SpringMvc_MyBatis_test2/WebRoot/WEB-INF/classes/cn/itcast/ssm/poDEBUG [main] - Find JAR URL: file:/D:/Java_Web_Project/SpringMvc_MyBatis_test2/WebRoot/WEB-INF/classes/cn/itcast/ssm/po/User.classDEBUG [main] - Not a JAR: file:/D:/Java_Web_Project/SpringMvc_MyBatis_test2/WebRoot/WEB-INF/classes/cn/itcast/ssm/po/User.classDEBUG [main] - Reader entry: ����DEBUG [main] - Checking to see if class cn.itcast.ssm.po.User matches criteria [is assignable to Object]INFO [main] - Destroying singletons in org.springframework.beans.factory.support.DefaultListableBeanFactory@12ad972d: defining beans [org.springframework.context.support.PropertySourcesPlaceholderConfigurer#0,dataSource,sqlSessionFactory,userDao,org.mybatis.spring.mapper.MapperScannerConfigurer#0,org.springframework.context.annotation.internalConfigurationAnnotationProcessor,org.springframework.context.annotation.internalAutowiredAnnotationProcessor,org.springframework.context.annotation.internalRequiredAnnotationProcessor,org.springframework.context.annotation.internalCommonAnnotationProcessor,org.springframework.context.annotation.internalPersistenceAnnotationProcessor]; root of factory hierarchyDEBUG [main] - Invoking destroy method 'close' on bean with name 'dataSource'


错误原因:.xml 中类名不对应,没有该类

错误片段

User.xml

 <insert id="insertUser" parameterType="cn.itcast.ssmk.po.User"> <!-- 将插入数据的主键返回,返回到user对象中=================SELECT LAST_INSERT_ID():得到刚insert进去记录的主键值,只适用与自增主键keyProperty:将查询到主键值设置到parameterType指定的对象的哪个属性order:SELECT LAST_INSERT_ID()执行顺序,相对于insert语句来说它的执行顺序resultType:指定SELECT LAST_INSERT_ID()的结果类型 --> <selectKey keyProperty="id" order="AFTER" resultType="java.lang.Integer"> SELECT LAST_INSERT_ID() </selectKey> INSERT INTO user(username,birthday,sex,address) VALUES(#{username},#{birthday},#{sex},#{address})  <!-- 使用mysql的uuid()生成主键执行过程:首先通过uuid()得到主键,将主键设置到user对象的id属性中其次在insert执行时,从user对象中取出id属性值 --><!--  <selectKey keyProperty="id" order="BEFORE" resultType="java.lang.String">SELECT uuid()</selectKey>insert into user(id,username,birthday,sex,address) value(#{id},#{username},#{birthday},#{sex},#{address}) --> </insert>


 <insert id="insertUser" parameterType="cn.itcast.ssmk.po.User">

cn.itcast.ssmk.po.User 包名写错,导致SqlSessionFactory无法注入


Spring 配置文件 applicationContext.xml       使用dbcp数据源

<beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:mvc="http://www.springframework.org/schema/mvc"xmlns:context="http://www.springframework.org/schema/context"xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.2.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.2.xsd "><!-- 加载配置文件 --><context:property-placeholder location="classpath:db.properties" /><!-- 数据源,使用dbcp --><bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"destroy-method="close"><property name="driverClassName" value="${jdbc.driver}" /><property name="url" value="${jdbc.url}" /><property name="username" value="${jdbc.username}" /><property name="password" value="${jdbc.password}" /><property name="maxActive" value="10" /><property name="maxIdle" value="5" /></bean><!-- sqlSessinFactory --><bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"><!-- 加载mybatis的配置文件 --><property name="configLocation" value="mybatis/SqlMapConfig.xml" /><!-- 数据源 --><property name="dataSource" ref="dataSource" /></bean><!-- 原始dao接口 --><bean id="userDao" class="cn.itcast.ssm.dao.UserDaoImpl"><property name="sqlSessionFactory" ref="sqlSessionFactory"/></bean></beans>


Mybatis 配置文件

<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd"><configuration><!-- 别名定义 --><typeAliases><!-- 批量别名定义 指定包名,mybatis自动扫描包中的po类,自动定义别名,别名就是类名(首字母大写或小写都可以)--><package name="cn.itcast.ssm.po"/></typeAliases><!-- 加载 映射文件 --><mappers><mapper resource="sqlmap/User.xml"/><!-- 批量加载mapper指定mapper接口的包名,mybatis自动扫描包下边所有mapper接口进行加载遵循一些规范:需要将mapper接口类名和mapper.xml映射文件名称保持一致,且在一个目录 中上边规范的前提是:使用的是mapper代理方法和spring整合后,使用mapper扫描器,这里不需要配置了 --><!-- <package name="cn.itcast.ssm.mapper"/> --></mappers></configuration>


工程组织结构




0 0
原创粉丝点击