Mybatis动态SQL注解开发操作数据库

发布时间:2024年01月05日

通过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 {
    @Autowired
    private PersonMapper personMapper;

    /**
     * 测试mybatis中xml方式操作数据库
     */
    @Test
    public  void testPersonMapper(){
        Person person = personMapper.selectById(1);
        System.out.println(person);
    }

    /**
     * 测试mybatis动态SQL语法
     */
    @Test
    public  void testSelectPersonByDynamicSql(){
       Person person =  personMapper.getPersonByIdFromDynamicSql(1);
       System.out.println(person);
    }
    @Test
    public  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);

    }
    @Test
    public void testUpdatePersonByDynamicSql(){
        Person person = new Person();
        person.setAge(35);
        person.setId(1);
        personMapper.updatePersonByDynamicSql(person);

    }
    @Test
    public  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。

文章来源:https://blog.csdn.net/weixin_42670590/article/details/135374284
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。