MyBatis与Spring集成映射器及动态SQL
时间: 2023-06-13 15:03:54 浏览: 136
MyBatis和Spring的集成非常方便,可以通过Spring提供的MapperFactoryBean来创建映射器。MapperFactoryBean是一个FactoryBean,用于创建MyBatis的映射器。它可以自动创建映射器的实例,并使用Spring的注入机制自动将需要的依赖注入到映射器中。
MapperFactoryBean的配置如下:
```xml
<bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">
<property name="mapperInterface" value="com.example.mybatis.UserMapper"/>
<property name="sqlSessionFactory" ref="sqlSessionFactory"/>
</bean>
```
其中,mapperInterface属性指定了映射器的接口类,sqlSessionFactory属性指定了MyBatis的SqlSessionFactory实例。
在映射器接口中,可以使用MyBatis提供的注解来构建动态SQL语句。例如:
```java
public interface UserMapper {
@Select("SELECT * FROM user WHERE username = #{username}")
User findByUsername(String username);
@Insert("INSERT INTO user (username, password) VALUES (#{username}, #{password})")
void insert(User user);
@Update("UPDATE user SET password = #{password} WHERE id = #{id}")
void updatePassword(User user);
@Delete("DELETE FROM user WHERE id = #{id}")
void deleteById(long id);
@SelectProvider(type = UserSqlProvider.class, method = "findUsers")
List<User> findUsers(String username, String email);
class UserSqlProvider {
public String findUsers(String username, String email) {
StringBuilder sql = new StringBuilder("SELECT * FROM user WHERE 1 = 1");
if (username != null) {
sql.append(" AND username = #{username}");
}
if (email != null) {
sql.append(" AND email = #{email}");
}
return sql.toString();
}
}
}
```
在这个例子中,使用@Select、@Insert、@Update和@Delete注解来构建静态SQL语句。使用@SelectProvider注解来构建动态SQL语句。其中,@SelectProvider注解指定了SQL语句构建类的类型和方法名。
在UserSqlProvider类中,使用StringBuilder来构建SQL语句。通过判断参数是否为空,来决定是否拼接相应的SQL语句片段。最后,返回完整的SQL语句。
以上就是MyBatis和Spring集成映射器及动态SQL的简单介绍。
阅读全文