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

基于 mybatis (和 mybatis plus) 能否实现在给 POJO 中的字段注入查到的值后,立刻去做另外一件事?

  •  
  •   BraveXaiver · 2023-10-20 11:24:56 +08:00 · 851 次点击
    这是一个创建于 407 天前的主题,其中的信息可能已经有所发展或是发生改变。
    比如受限于之前设计的不完善,交易的状态列只有 char(1),现在希望在 POJO 中增加一个 trxnDetailedStatus 字段,是对单个字符的交易字段的详细描述。比如 A 代表已批准,P 代表等待批准。

    我们的 java 程序使用 mybatis 和 mybatis plus ,希望能做到从数据库取出这条记录生成 POJO 时,在 trxnStatus 字段被填入 "A" 后,就实现为 trxnDetailedStatus 字段填入“Approved”

    谢谢!
    10 条回复    2023-10-20 17:35:14 +08:00
    wetalk
        1
    wetalk  
       2023-10-20 11:33:39 +08:00   ❤️ 1
    类似表内字段联动吧,写个拦截器咯,plus 中没见过类似用途的工具
    28Sv0ngQfIE7Yloe
        2
    28Sv0ngQfIE7Yloe  
       2023-10-20 11:37:06 +08:00
    只用过 插入和更新填充,不知道 select 时能不能填充
    lalawu
        3
    lalawu  
       2023-10-20 11:39:50 +08:00
    typeHandler ?
    InkAndBanner
        4
    InkAndBanner  
       2023-10-20 13:34:28 +08:00
    楼上正解
    BraveXaiver
        5
    BraveXaiver  
    OP
       2023-10-20 13:52:27 +08:00
    @Morii 能介绍下思路吗?

    @lalawu
    @InkAndBanner typeHandler 针对 String 到 String 的转换也好用吗?打击面会不会太广泛了呀。。
    qluuu
        6
    qluuu  
       2023-10-20 13:59:05 +08:00
    要不直接重写下 trxnStatus set 方法 同时给 trxnDetailedStatus 赋值
    L0L
        7
    L0L  
       2023-10-20 14:06:06 +08:00
    @BraveXaiver 不一刀切,注解配合 pojo 类玩一波?办法总比问题多
    xlzyxxn
        8
    xlzyxxn  
       2023-10-20 14:18:15 +08:00
    简单的话就 6 楼这样直接写就完了
    ssrfw
        9
    ssrfw  
       2023-10-20 14:46:22 +08:00
    六楼方法最简单 设置 po 的时候 是调用的 set 方法
    nerkeler
        10
    nerkeler  
       2023-10-20 17:35:14 +08:00
    select case trxnStatus when 'A' then “Approved” when 'P' then ... end trxnDetailedStatus
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2622 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 27ms · UTC 11:14 · PVG 19:14 · LAX 03:14 · JFK 06:14
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.