Spring @Scheduled定时任务的fixedRate,fixedDelay,cron的作用和不同

一.   三种定时类型。

1.cron  --@Scheduled(cron="0/5 * * * *?")

   当时间达到设置的时间会触发事件。上面那个例子会每5秒执行一次。

  • 2018/1/4 14:27:30
  • 2018/1/4 14:27:35
  • 2018/1/4 14:27:40
  • 2018/1/4 14:27:45
  • 2018/1/4 14:27:50
2.fixedRate --@Scheduled(fixedRate=2000
 每两秒执行一次时间。
3.fixedDelay --@Scheduled(fixedDelay=2000
 每次任务执行完之后的2s后继续执行

看字面意思容易理解,但是任务执行长度超过周期会怎样呢?

不多说,直接上图:


import java.text.DateFormat;  
import java.text.SimpleDateFormat;  
import java.util.Date;  
  
  
import org.springframework.scheduling.annotation.Scheduled;  
import org.springframework.stereotype.Component;  
  
  
@Component  
public class MyProcessor{  
      
    DateFormat sdf = new SimpleDateFormat("HH:mm:ss");  
      
    int[] delays = new int[]{8,3,6,2,2};  
    int index = 0;  
      
    @Scheduled(cron = "0/5 * * * * ?}")  
    public void process() {  
        try {  
            if(index > delays.length - 1){  
                if(index == delays.length){  
                    System.out.println("---------- test end at " + sdf.format(new Date()) + " ---------");  
                }  
                index ++;  
                return;  
            }else{  
                System.out.println(index + ":start run at" + sdf.format(new Date()));  
            }  
            Thread.sleep(delays[index] * 1000);  
            System.out.println(index + ":end run at " + sdf.format(new Date()));  
            index ++;   
        } catch (InterruptedException e) {  
            e.printStackTrace();  
        }  
    }  
}  

Spring Boot 中使用 MybatisPlus 实现模糊查询并分页,可以按照如下步骤: 1. 在 pom.xml 文件中添加 MybatisPlus 的依赖: ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>${mybatis-plus.version}</version> </dependency> ``` 2. 在 application.properties 文件中添加 MybatisPlus 的配置: ```properties # MybatisPlus 配置 mybatis-plus.mapper-locations=classpath*:mapper/*.xml mybatis-plus.type-aliases-package=com.example.entity ``` 3. 创建一个 MybatisPlus 的配置类 MybatisPlusConfig,并开启分页功能: ```java @Configuration @MapperScan("com.example.mapper") public class MybatisPlusConfig { @Bean public PaginationInterceptor paginationInterceptor() { PaginationInterceptor paginationInterceptor = new PaginationInterceptor(); return paginationInterceptor; } } ``` 4. 在 Mapper 接口中定义一个分页查询方法,如下所示: ```java public interface UserMapper extends BaseMapper<User> { IPage<User> selectUserPage(Page<User> page, @Param("name") String name); } ``` 其中,`Page` 是 MybatisPlus 提供的分页对象,`@Param("name")` 表示传入的参数名称是 `name`。 5. 在 Mapper.xml 文件中实现分页查询方法: ```xml <select id="selectUserPage" resultType="com.example.entity.User"> select * from user where name like concat('%', #{name}, '%') order by id desc </select> ``` 其中,`concat` 函数用于拼接字符串,`#{name}` 表示传入的参数值是 `name`。 6. 在 Service 层中调用分页查询方法: ```java @Service public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService { @Override public IPage<User> selectUserPage(Page<User> page, String name) { return baseMapper.selectUserPage(page, name); } } ``` 其中,`baseMapper` 是 MybatisPlus 提供的基础 Mapper 类,可以直接调用 Mapper 接口中定义的方法。 7. 最后,在 Controller 层中调用 Service 层中的分页查询方法,并将查询结果返回给前端: ```java @RestController @RequestMapping("/user") public class UserController { @Autowired private UserService userService; @GetMapping("/list") public IPage<User> selectUserPage(Page<User> page, String name) { return userService.selectUserPage(page, name); } } ``` 以上就是在 Spring Boot 中使用 MybatisPlus 实现模糊查询并分页的步骤。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值