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

通过Mybatis的动态注解开发,只需要在映射文件中使用注解来配置映射关系,从而无需编写XML映射文件。常用的注解有@Select,@Update,@Insert,@Delete等,它们分别用于配置查询,更新,插入和删除操作。

**方式一:**在mapper文件中使用@Select,@Update,@Insert,@Delete注解

1、定义数据模型类Person.java

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下添加如下内容:

java 复制代码
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文件中添加测试用例

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("[email protected]");
        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语句的示例:

java 复制代码
//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语句的注解。

java 复制代码
@SelectProvider(type = UserSqlProvider.class, method = "getUserById")
User getUserById(Long id);

在这个例子中,@SelectProvider注解指定了Provider接口的类型和方法,Provider接口中包含了生成SELECT语句的方法getUserById。

2、@InsertProvider:用于动态生成INSERT语句的注解。

java 复制代码
@InsertProvider(type = UserSqlProvider.class, method = "insertUser")
void insertUser(User user);

在这个例子中,@InsertProvider注解指定了Provider接口的类型和方法,Provider接口中包含了生成INSERT语句的方法insertUser。

3、@UpdateProvider:用于动态生成UPDATE语句的注解。

java 复制代码
@UpdateProvider(type = UserSqlProvider.class, method = "updateUser")
void updateUser(User user);

在这个例子中,@UpdateProvider注解指定了Provider接口的类型和方法,Provider接口中包含了生成UPDATE语句的方法updateUser。

4、@DeleteProvider:用于动态生成DELETE语句的注解。

java 复制代码
@DeleteProvider(type = UserSqlProvider.class, method = "deleteUser")
void deleteUser(Long id);

在这个例子中,@DeleteProvider注解指定了Provider接口的类型和方法,Provider接口中包含了生成DELETE语句的方法deleteUser。

相关推荐
一 乐1 小时前
民宿|基于java的民宿推荐系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·源码
爱记录的小磊1 小时前
java-selenium自动化快速入门
java·selenium·自动化
鹏码纵横1 小时前
已解决:java.lang.ClassNotFoundException: com.mysql.jdbc.Driver 异常的正确解决方法,亲测有效!!!
java·python·mysql
weixin_985432111 小时前
Spring Boot 中的 @ConditionalOnBean 注解详解
java·spring boot·后端
Mr Aokey1 小时前
Java UDP套接字编程:高效实时通信的实战应用与核心类解析
java·java-ee
冬天vs不冷1 小时前
Java分层开发必知:PO、BO、DTO、VO、POJO概念详解
java·开发语言
sunny-ll1 小时前
【C++】详解vector二维数组的全部操作(超细图例解析!!!)
c语言·开发语言·c++·算法·面试
hong_zc1 小时前
Java 文件操作与IO流
java·文件操作·io 流
猎人everest1 小时前
Django的HelloWorld程序
开发语言·python·django
木棉软糖2 小时前
【记录坑点问题】IDEA运行:maven-resources-production:XX: OOM: Java heap space
java·maven·intellij-idea