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

请教一个小白数据查询问题

  •  
  •   CUMTProgrammer · 2019-12-26 10:08:52 +08:00 · 1932 次点击
    这是一个创建于 1794 天前的主题,其中的信息可能已经有所发展或是发生改变。
    A 里面有一个 list<b>,b 现在只有 id。现在我想数据库查 b,是批量查好还是循环查好。

    循环查需要发很多请求,但是很好写,getById 然后 set 进去就行了。

    批量的话,需要先循环一次整理 B 的 id,然后查询出来之后。还得循环匹配,list<b>循环一次,里面还得循环查询结果,通过 id 匹配,然后 set 进去,感觉很麻烦的样子。

    或者各位大佬还有什么更好的办法
    7 条回复    2019-12-27 10:26:57 +08:00
    mituxiaomanong
        1
    mituxiaomanong  
       2019-12-26 10:45:47 +08:00 via Android
    批量查。你可以写一些到反射的辅助方法就不麻烦了
    manami
        2
    manami  
       2019-12-26 10:54:13 +08:00
    一直都是循环查。批量查如果是在 xml 里写 sql 用到 foreach 类似的标签语句感觉很丑,有其他复杂的条件判断的话更难看,修改也不方便。
    feigle
        3
    feigle  
       2019-12-26 10:58:03 +08:00
    遍历 list<b>,得到所有的 id,然后去数据库把得到的 id 都查出来,不就可以了
    phantomzz
        4
    phantomzz  
       2019-12-26 10:59:43 +08:00
    对性能要求不高,可以循环查。
    反之,要考虑 IO 开销
    hijoker
        5
    hijoker  
       2019-12-26 11:27:27 +08:00
    楼主是 cumt 的?
    wysnylc
        6
    wysnylc  
       2019-12-26 11:56:33 +08:00
    in 查询,不要循环查
    Aliberter
        7
    Aliberter  
       2019-12-27 10:26:57 +08:00
    看数据量大小吧,循环查连接过多可能会崩的,但是如果你查出来后,针对每个 id 又要有很多的业务处理,还是写循环查最简洁清晰。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1982 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 00:24 · PVG 08:24 · LAX 16:24 · JFK 19:24
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.