V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
madworks
V2EX  ›  Java

mybatis 分页拦截器使用方式里 pagehelper 和 mybatis 查询之间不能有其他逻辑处理,请问下这是不是不合理的, 21 个想问下这种是怎么实现的,比较好奇

  •  
  •   madworks · 2020-10-27 14:28:07 +08:00 · 1466 次点击
    这是一个创建于 1489 天前的主题,其中的信息可能已经有所发展或是发生改变。
    3 条回复    2020-10-27 15:12:25 +08:00
    THESDZ
        1
    THESDZ  
       2020-10-27 14:42:09 +08:00
    1.写分页参数,紧接着执行查询,这样很合理
    2.设置线程变量,拦截器读取线程变量

    根据 2 可知,线程变量的存储和获取是分开的,如果中间加入其它逻辑
    2.1.影响代码可阅读性
    2.2.查询数据库应该明确自身想查什么,如果中间插入业务逻辑,就会导致我查数据库这一步的完整性被打破了
    2.3.业务逻辑可能会访问数据库或者等等,导致分页的拦截器有问题
    wanacry
        2
    wanacry  
       2020-10-27 15:01:53 +08:00
    我也想问,每次从库查出来的数据还要转 vo 碰到 pagehelper 分页就不爽
    madworks
        3
    madworks  
    OP
       2020-10-27 15:12:25 +08:00
    @THESDZ 谢谢,2 说的很有道理
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   945 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 22:43 · PVG 06:43 · LAX 14:43 · JFK 17:43
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.