通过Mybatis的动态注解开发,只需要在映射文件中使用注解来配置映射关系,从而无需编写XML映射文件。常用的注解有@Select,@Update,@Insert,@Delete等,它们分别用于配置查询,更新,插入和删除操作。
方式一:在mapper文件中使用@Select,@Update,@Insert,@Delete注解
1、定义数据模型类Person.java
package com.lingyi.mybatis.bean;import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;import java.util.Date;@Data
@NoArgsConstructor
@AllArgsConstructor
@TableName(value = "person")
public class Person {@TableId(value = "id",type = IdType.AUTO)private Integer id;private Integer age;private Date birthday;private String email;private String name;private String gender;private Double salary;
}
2、编写Mapper接口
创建一个PersonMapper接口,用于定义用户与数据库的相关操作,在接口方法上使用Mybatis的注解完成SQL操作。其中PersonMapper接口可以继承mybatis的BaseMapper,也可以不继承BaseMapper。下面在原有工程的PersonMapper下添加如下内容:
package com.lingyi.mybatis.mapper;import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.lingyi.mybatis.bean.Person;
import org.apache.ibatis.annotations.*;/**** BaseMapper是MyBatisPlus内置的通用Mapper,提供了很多的方法* 如果它提供的方法不能满足业务需求,我们可以在这里开发新的方法*/
//这里可以不需要填写@Mapper注解,因为在Applicaton.java的入口文件指明扫描了Mapper文件所在的包@MapperScan(basePackages = {"com.lingyi.mybatis.mapper"})
@Mapper
public interface PersonMapper extends BaseMapper<Person> {//mapper中自定义操作数据库的方法,通过xml方式,在xml文件中定义。public Person getPersonById(Integer id);//mybatis动态SQL方式操作数据库@Select("select * from person where id = #{id}")Person getPersonByIdFromDynamicSql(@Param( "id") int id);@Insert("insert into person (age,birthday,email,gender,name,salary) Values(#{age},#{birthday},#{email},#{gender},#{name},#{salary})")int insertPesonByDynamicSql(Person person);@Update("update person set age = #{age} where id = #{id}")int updatePersonByDynamicSql(Person person);@Delete("delete from person where id = #{id}")int deletePersonByDynamicSql(Person person);}
3、编写测试用例
在原有工程的TestPersonMapper.java文件中添加测试用例
package com.lingyi.mybatis;import com.lingyi.mybatis.bean.Person;
import com.lingyi.mybatis.mapper.PersonMapper;
import jakarta.annotation.Resource;
import org.junit.jupiter.api.Test;import org.mybatis.spring.annotation.MapperScan;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;@SpringBootTest
public class TestPersonMapper {@Autowiredprivate PersonMapper personMapper;/*** 测试mybatis中xml方式操作数据库*/@Testpublic void testPersonMapper(){Person person = personMapper.selectById(1);System.out.println(person);}/*** 测试mybatis动态SQL语法*/@Testpublic void testSelectPersonByDynamicSql(){Person person = personMapper.getPersonByIdFromDynamicSql(1);System.out.println(person);}@Testpublic void testInsertPersonByByDynamicSql(){Person person = new Person();person.setAge(45);person.setName("lisi");person.setGender("男");person.setSalary(30000.0);person.setEmail("1234@qq.com");personMapper.insertPesonByDynamicSql(person);}@Testpublic void testUpdatePersonByDynamicSql(){Person person = new Person();person.setAge(35);person.setId(1);personMapper.updatePersonByDynamicSql(person);}@Testpublic void testDeletePersonByDynamicSql(){Person person = new Person();person.setId(16);personMapper.deletePersonByDynamicSql(person);}
}
方式二:在Mapper接口中使用@SelectProvider或者@InsertProvider,@UpdateProvider,@DeleteProvider注解来实现动态生成SQL语句。
以下是一个使用@Select注解和Provider接口来动态生成SELECT语句的示例:
//mapper接口中
public interface PersonMapper {@SelectProvider(type = PersonSqlProvider.class, method = "getPersonFromProviderById")User getPersonFromProviderById(Long id);
}//PersonSqlProvider类中
public class PersonSqlProvider {public String getPersonFromProviderById(Long id) {return "SELECT * FROM person WHERE id = " + id;}
}
在上面的示例中,@SelectProvider注解指定了Provider接口的类型和方法,Provider接口中包含了生成SELECT语句的方法getPersonFromProviderById。在Provider接口的getPersonFromProviderById方法中,可以根据传入的参数动态生成SELECT语句。
通过这种方式,开发者可以根据不同的条件动态生成SELECT语句,从而实现更灵活的数据库查询操作。
在MyBatis中,可以使用动态SQL注解来实现动态生成SQL语句。以下是一些常用的动态SQL注解以及它们的使用方法:
1、@SelectProvider:用于动态生成SELECT语句的注解。
@SelectProvider(type = UserSqlProvider.class, method = "getUserById")
User getUserById(Long id);
在这个例子中,@SelectProvider注解指定了Provider接口的类型和方法,Provider接口中包含了生成SELECT语句的方法getUserById。
2、@InsertProvider:用于动态生成INSERT语句的注解。
@InsertProvider(type = UserSqlProvider.class, method = "insertUser")
void insertUser(User user);
在这个例子中,@InsertProvider注解指定了Provider接口的类型和方法,Provider接口中包含了生成INSERT语句的方法insertUser。
3、@UpdateProvider:用于动态生成UPDATE语句的注解。
@UpdateProvider(type = UserSqlProvider.class, method = "updateUser")
void updateUser(User user);
在这个例子中,@UpdateProvider注解指定了Provider接口的类型和方法,Provider接口中包含了生成UPDATE语句的方法updateUser。
4、@DeleteProvider:用于动态生成DELETE语句的注解。
@DeleteProvider(type = UserSqlProvider.class, method = "deleteUser")
void deleteUser(Long id);
在这个例子中,@DeleteProvider注解指定了Provider接口的类型和方法,Provider接口中包含了生成DELETE语句的方法deleteUser。