簡體   English   中英

基於XML + Annotation的MyBatis配置

[英]XML + Annotation based configuration for MyBatis

是否可以在應用程序中同時具有基於XML + Annotation的MyBatis配置。

我之所以這樣問,是因為在我的應用程序中,我使用的是基於注釋的方法。 但是在一種情況下,我需要使用IN子句,可以使用

<foreach></foreach>

基於XML的配置。

但是,當我啟動應用程序時,它似乎無法識別基於Annotation的映射器,並為我提供Type interface is not known to the MapperRegistry異常Type interface is not known to the MapperRegistry

因此,我想知道是否可以在應用程序中同時為MyBatis提供基於XML + Annotation的配置。 請提出建議。

可能同時具有基於XML + Annotation的配置

對於基於xml的配置:

從Spring上下文文件開始,在上下文文件中添加以下行

<beans:bean id="dataSource"
              class="org.springframework.jdbc.datasource.DriverManagerDataSource"
              p:driverClassName="yourDriverClassName"
              p:url="yourUrl"
              p:username="yourUsername"
              p:password="yourPassword" />

<beans:bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    <beans:property name="dataSource" ref="dataSource" />
    <beans:property name="configLocation" value="/WEB-INF/mybatis-config.xml" />
</beans:bean>
<!-- assuming you have a dao named UserDao -->
<beans:bean id="userDao" class="com.yourcomp.dao.Userdao">
    <beans:property name="sqlSessionFactory" ref="sqlSessionFactory" />
</beans:bean>

您的mybatis-config.xml應該是這樣的:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">

<configuration>
  <settings>

  </settings>
  <typeAliases>

    <typeAlias alias="User" type ="com.yourcomp.domain.User" />

  </typeAliases>
  <mappers>

    <mapper resource="com/yourcomp/domain/UserMapper.xml"/>
    <mapper resource="com/yourcomp/domain/AnotherDomainObjectMapper.xml"/>
  </mappers>

</configuration>

和src / com / yourcomp / domain /中的userMapper.xml可能是這樣的

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--<mapper namespace="org.pbl.rms.RMSUserDao">-->

<mapper namespace="com.yourcomp.domain.User">

  <resultMap id="userMap" type="User">
  <id property="userId" column="USER_ID" javaType="int" jdbcType="NUMERIC"/>
  <result property="userName"  column="USER_NAME" javaType="String" jdbcType="VARCHAR"/>
  <result property="userFullName"  column="USER_FULL_NAME" javaType="String" jdbcType="VARCHAR"/>
  <result property="password"  column="PASSWORD" javaType="String" jdbcType="VARCHAR"/>
  <result property="passwordExpiryDate"  column="PASWRD_EXPIRY_DATE" javaType="java.util.Date" jdbcType="DATE"/>
  <result property="status" column="STATUS" javaType="_integer" jdbcType="DECIMAL"/>
  </resultMap>

  <select id="getUserById" parameterType="map" resultMap="userMap">
  select  * from user where USER_ID=#{userId}
  </select>

</mapper>

現在,在您的DAO層中,您可能會擁有如下所示的類:

public class UserDAO{

    private SqlSessionFactory sqlSessionFactory;

    public UserDAO() {

    }

    public UserDAO(SqlSessionFactory sqlSessionFactory ) {
        this.sqlSessionFactory = sqlSessionFactory;

    }
    public String getUserById(Integer userId) {
        SqlSession session = sqlSessionFactory.openSession();
        //int success = -100;
        String name=null;
        try {
            name = (String)session.selectOne("com.yourcomp.domain.User.getUserById",userId);
        }catch(Exception e){

        }finally {
            session.close();
        }
        return name;
    }
}

現在,要使用基於注釋的配置,請添加以下內容:

您可能具有如下界面:

public interface MyMapper {
    @Select(value="select something from some_table")
    public String getSomeValue(@Param("someParam") String someParam);

}

現在將以下內容添加到您的上下文文件中:

<beans:bean id="annotatedMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">
  <beans:property name="mapperInterface" value="com.yourcomp.MyMapper" />
  <!-- remember the sqlsession factory defined earlier for xml based conf ? -->
  <beans:property name="sqlSessionFactory" ref="sqlSessionFactory" />
</beans:bean>

希望這可以幫助 :)

以下標簽也可用於基於注釋的方法。
<foreach> </ foreach>

在這種情況下,您將不需要兩個映射器文件。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM