Mapper.java 与 Mapper.xml 如何对应

Mapper.java 与 Mapper.xml 如何对应


问题描述:

某项目中检索 HbPkgEntityMapper.java 对应的 .xml 时有两个同名不同包的.xml
而Mapper.xml文件中<mapper namespace= ""> namespace 均为该 mapper.java 的路径,无法确认此时调用的是哪个对应的Mapper.xml


spring-mybatis.xml
    <!-- sqlSessionFactory -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"
        p:dataSource-ref="dynDataSource" p:typeAliasesPackage="com.jrd.packet.api.rule.model"
        p:mapperLocations="classpath*:com/**/mapping/*Mapper.xml">
        <property name="configLocation" value="classpath:conf/mybatis-config.xml" />
    </bean>
    <bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
        <constructor-arg index="0" ref="sqlSessionFactory" />
    </bean>

    <!-- 配置要扫描的UserMapper.xml -->
    <!-- <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer" -->
    <!-- p:basePackage="com.jrd.mapper" p:sqlSessionFactoryBeanName="sqlSessionFactory" 
        /> -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="com.jrd.packet.*.*.mapper" />
        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
    </bean>
  • sqlSessionFactory 中有相应配置
  • MapperScannerConfigurer :将 会 查 找 类 路 径 下 的 映 射 器 并 自 动 将 它 们 创 建 成 MapperFactoryBean
  • MapperFactoryBean :
  • basePackage 属性为映射器接口文件设置基本的包路径
  • 使用 sqlSessionFactoryBeanName 或 sqlSessionTemplateBeanName 属性来设置正确的 bean 名称来使用

参考资料

### 回答1: mapper.javamapper.xmlMyBatis框架中的两个重要文件。 mapper.java是一个Java接口,用于定义数据库操作的方法。在mapper.java中,我们可以定义增删改查等操作的方法,并且可以通过注解或XML文件来映射SQL语句。 mapper.xml是一个XML文件,用于定义SQL语句和参数映射。在mapper.xml中,我们可以定义SQL语句,以及SQL语句中的参数和返回值的映射关系。同时,我们也可以在mapper.xml中定义一些复杂的SQL语句,如多表查询、分页查询等。 在MyBatis框架中,mapper.javamapper.xml是一一对应的,即每个mapper.java对应一个mapper.xml文件。这种设计可以使代码更加清晰,易于维护。 ### 回答2: mapper.javamapper.xml都是MyBatis框架中的重要组成部分。其中mapper.javaMyBatis框架中定义DAO的接口,而mapper.xml是DAO接口的具体实现。 mapper.java是DAO层的接口,定义了基本的业务操作方法,例如查询、插入、更新、删除等。它主要由两部分组成:一是声明DAO接口的名称和方法,二是声明DAO接口方法的参数和返回值类型。 mapper.xml则是为DAO接口提供具体的实现。mapper.xml中定义了SQL语句,用于访问数据库。它包含SQL语句、参数映射、结果映射等信息。在MyBatis中,mapper.xml文件中的SQL语句是可以动态生成的,这使得MyBatis易于开发。 映射器的使用可以实现业务逻辑与数据访问之间的解耦。它们提供了一个清晰的接口,使开发人员能够快速实现数据访问逻辑。在使用MyBatis框架时,mapper.javamapper.xml通常是组合起来使用的,其中mapper.java提供的接口方法将会调用mapper.xml中定义的SQL语句来实现具体业务逻辑。这种实现方式非常灵活,并且易于维护。 ### 回答3: Mapper.javaMapper.xmlMyBatis框架描述SQL语句和Java类之间映射关系的两种方式。 Mapper.java是使用Java代码来描述SQL语句和对应的参数、返回值类型。Mapper.java中的方法对应SQL语句,参数是该语句需要传递的参数,返回值是SQL语句执行结果。Mapper.java可以使得编写Java程序更加直观,同时也可以静态类型检查,减少代码错误。 Mapper.xml则是使用XML文件来描述SQL语句和Java类之间的映射关系。Mapper.xml中包含了SQL语句、参数类型、返回值类型等信息,而且还可以使用一些特殊标签来处理SQL语句的动态条件、循环等逻辑。Mapper.xml可以使得SQL语句的编写更加灵活,而且可以方便地对SQL语句进行管理和调试。 在实际使用中,通常建议使用Mapper.xml描述复杂的SQL语句逻辑,而使用Mapper.java来描述简单的SQL语句。同时,Mapper.javaMapper.xml并不是互斥的,可以同时使用,也可以根据具体情况只使用其中一种。无论是使用Mapper.java还是Mapper.xml,都可以通过MyBatis框架来解析映射描述文件,并根据映射关系来执行SQL语句。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值