MybatisPlus+Oracle +时间范围查询+ROWNUM查询

引用地址:MybatisPlus+Oracle +时间范围查询+ROWNUM查询_mybatisplus oracle-CSDN博客

QueryWrapper条件构造器
时间范围查询

MybatisPlus操作时间区间做查询条件,可能大家大多用的 ge() le()方法,但是,这只能对于MySql,Oracle数据库时间是需要to_date('date','format')函数的,所以,用MybatisPlus操作Oracle时,直接用le()或ge()会导致一直爆sql异常,对此正确的写法应该是:

//SELECT * FROM table WHERE sj >= to_date('2024-05-27 14:17:41', 'yyyy-mm-dd hh24:mi:ss') AND sj <= to_date('2024-05-28 14:17:41', 'yyyy-mm-dd hh24:mi:ss');

String startTime = "2024-05-27 14:17:41";
String endTime = "2024-05-28 14:17:41";
LambdaQueryWrapper<YlgZhaji> queryWrapper = new LambdaQueryWrapper<>();
        queryWrapper.apply("sj >= To_DATE({0}, 'yyyy-MM-dd HH24:mi:ss') ", startTime )
                      .apply("sj <= To_DATE({0}, 'yyyy-MM-dd HH24:mi:ss') ", endTime);
                    .orderByAsc(YlgZhaji::getSj);

ROWNUM查询

使用oracle,查询10条数据。

//SELECT * FROM table WHERE ROWNUM <= 10;

LambdaQueryWrapper<YlgZhaji> queryWrapper = new LambdaQueryWrapper<>();
        queryWrapper.apply("ROWNUM <= 10")
                .orderByAsc(YlgZhaji::getSj);

————————————————

                            版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
                        
原文链接:https://blog.csdn.net/weixin_44885096/article/details/139239212

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用Mybatis Plus和Oracle实现分页的示例代码: 1.在pom.xml文件中添加Mybatis Plus的依赖: ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.4.2</version> </dependency> ``` 2.在application.yml文件中配置数据源和Mybatis Plus: ```yaml spring: datasource: url: jdbc:oracle:thin:@localhost:1521:orcl username: root password: 123456 driver-class-name: oracle.jdbc.driver.OracleDriver mybatis-plus: mapper-locations: classpath:/mapper/*.xml configuration: map-underscore-to-camel-case: true ``` 3.在Mapper接口中定义分页查询方法: ```java public interface UserMapper extends BaseMapper<User> { List<User> selectUserPage(Page<User> page, @Param("name") String name); } ``` 4.在Mapper.xml文件中实现分页查询: ```xml <select id="selectUserPage" resultType="com.example.demo.entity.User"> select * from ( select row_.*, rownum rownum_ from ( select * from user where name like concat('%', #{name}, '%') ) row_ where rownum <= #{current} * #{size} ) a where rownum_ > (#{current} - 1) * #{size} </select> ``` 5.在Service中调用分页查询方法: ```java @Service public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService { @Override public IPage<User> getUserPage(Page<User> page, String name) { return baseMapper.selectUserPage(page, name); } } ``` 以上就是使用Mybatis Plus和Oracle实现分页的示例代码。需要注意的是,在Mapper.xml文件中的SQL语句中,需要使用rownum来实现分页,同时需要将查询结果的列名改为rownum_,否则会出现错误。另外,需要在查询语句中使用concat函数来实现模糊查询。如果需要其他类型的分页查询,可以根据类似的方式进行实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值