数据库的事务、锁、应用层的 service 接口问题 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
huyangq
V2EX    数据库

数据库的事务、锁、应用层的 service 接口问题

  •  
  •   huyangq 348 天前 1731 次点击
    这是一个创建于 348 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我有 2 个接口,一个是读取表内容 一个是更新表 需求是保证数据正确,我应该如何写代码?是在应用层的接口层面 使用 java 的锁来保证这 2 个接口互斥吗? 听说串行化不推荐使用? 到底应该如何写代码?

    14 条回复    2024-11-05 09:36:54 +08:00
    MoYi123
        1
    MoYi123  
       348 天前
    一般情况下是 读取表 写个 select 更新表写个 update, 其他都不用管.
    Plutooo
        2
    Plutooo  
       348 天前
    两个接口各干各的会有什么问题吗
    csys
        3
    csys  
       348 天前
    如果是两个接口 为啥要“保证数据正确”呢

    一般只有在单个事务场景才会需要保证强一致性

    这和串行不串行没啥关系,因为你没法知道调用方”读“多久,除非它主动告诉你自己”读“使用完了

    如果要锁的话,锁的生命周期就是得由调用方来控制了
    nice2cu
        4
    nice2cu  
       348 天前
    没懂啥意思 update 的 service 方法加事务就行吧防止读未提交或出现回滚 查询不用管
    chenjk
        5
    chenjk  
       348 天前
    没理解,读、写接口本来就互不影响,可以详细说说 (:
    xiaogu2014
        6
    xiaogu2014  
       348 天前
    ```需求是保证数据正确```
    你设置 db isolation level 不要是 read uncommitted 就可以了。
    读取和写为啥要互斥呢=。 除非是写和写之间。
    coderxy
        7
    coderxy  
       348 天前
    最简单的做法就是加一个分布式锁保证两个接口互斥, 但是如果你数据库有主从的话,也没办法保证拿到的一定是最新的数据。
    coderYang
        8
    coderYang  
       348 天前
    应用层的 Service 应该是要退出讨论的,你描述就是并发环境下的数据库修改。不同 db 的限制不同,例如 mysql 就是 mvcc ,不同的事务等级在遇到并发问题的处理方案不同。
    b821025551b
        9
    b821025551b  
       348 天前
    这个看起来有些奇怪,不过按照你这个需求,在应用层上倒是有一些思路:

    写的接口传入读的数据,写入前进行校验,如果不一致抛出信息。
    gitlight
        10
    gitlight  
       348 天前
    你的需求只需要保证读取出来的不是未提交的写入就可以了,把数据库的事务等级调整一下就好了,就是 6l 的建议;
    或者你想在后端实现,其实也简单,实现一个简单的 cas 就行,比如给表加个 version 字段
    vishun
        11
    vishun  
       347 天前
    照你现有的描述的话压根不需要做任何处理。
    怀疑你描述有问题,猜测是为了读取内容后立即修改,如果是这样就是最基本的写并发问题。
    heiya
        12
    heiya  
       347 天前
    感觉具体得看什么属性的数据。
    1.如果是共享数据,如果不锁住读取的表内容,就会有并发导致的数据不正确的风险。可以在数据库中加一个乐观锁/悲观锁。
    2.不是共享数据,串行化就 ok
    huyangq
        13
    huyangq  
    OP
       347 天前
    @xiaogu2014 如果不互斥的话,读到的数据 可能不是最新的数据吧
    huyangq
        14
    huyangq  
    OP
       347 天前
    @heiya 是共享的数据
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     1421 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 22ms UTC 16:53 PVG 00:53 LAX 09:53 JFK 12:53
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86