groovy下mybatis的映射如何处理

avatar
作者
猴君
阅读量:0

在Groovy中使用MyBatis时,你需要遵循以下步骤来处理映射文件:

  1. 添加依赖

首先,确保你的项目中已经添加了MyBatis和Groovy的依赖。在build.gradle文件中添加以下依赖:

dependencies {     implementation 'org.mybatis:mybatis:3.5.7'     implementation 'org.mybatis.groovy:mybatis-groovy:2.0.6' } 
  1. 创建Mapper接口

创建一个与映射文件对应的Mapper接口。例如,如果你的映射文件名为UserMapper.xml,则创建一个名为UserMapper的接口:

interface UserMapper {     User getUserById(int id)     List<User> getUsers() } 
  1. 编写映射文件

resources目录下创建一个名为mapper的文件夹,然后在其中创建与Mapper接口对应的映射文件。例如,创建一个名为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="com.example.mapper.UserMapper">     <select id="getUserById" resultType="com.example.model.User">         SELECT * FROM user WHERE id = #{id}     </select>      <select id="getUsers" resultType="com.example.model.User">         SELECT * FROM user     </select> </mapper> 

注意namespace属性应与Mapper接口的全限定名相匹配。

  1. 配置MyBatis

创建一个名为MyBatisConfig的Groovy类,用于配置MyBatis。在这个类中,你需要注册Mapper接口和映射文件:

import org.apache.ibatis.builder.xml.XMLMapperBuilder import org.apache.ibatis.io.Resources import org.mybatis.spring.SqlSessionFactoryBean import org.springframework.beans.factory.annotation.Value import org.springframework.context.annotation.Bean import org.springframework.context.annotation.Configuration  import javax.sql.DataSource; import java.io.IOException  @Configuration class MyBatisConfig {      @Value("${mybatis.mapper-locations}")     private String mapperLocations      @Bean     SqlSessionFactoryBean sqlSessionFactory(DataSource dataSource) throws IOException {         SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean()         sessionFactory.setDataSource(dataSource)          Resources resources = new Resources(mapperLocations)         for (String resource : resources.getResourceNames()) {             XMLMapperBuilder xmlMapperBuilder = new XMLMapperBuilder(resources.getInputStream(resource), sessionFactory.getConfiguration(), resource, sessionFactory.getSqlFragments())             xmlMapperBuilder.parse()         }          return sessionFactory     } } 

注意@Value("${mybatis.mapper-locations}")注解用于注入映射文件的位置。你需要在application.propertiesapplication.yml文件中配置这个属性,例如:

mybatis.mapper-locations=classpath:mapper/*.xml 
  1. 使用Mapper

现在你可以在你的服务类中使用SqlSessionTemplate来执行数据库操作。首先,注入SqlSessionTemplate

import org.mybatis.spring.SqlSessionTemplate import org.springframework.beans.factory.annotation.Autowired import org.springframework.stereotype.Service  @Service class UserService {      @Autowired     SqlSessionTemplate sqlSessionTemplate      UserMapper userMapper      User getUserById(int id) {         return userMapper.getUserById(id)     }      List<User> getUsers() {         return userMapper.getUsers()     } } 

注意SqlSessionTemplate会自动处理Mapper接口和映射文件之间的关联。现在你可以使用UserService类来执行数据库操作了。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!