请教一个多线程同时查询数据库问题

请教一个多线程同时查询数据库问题,第1张

线程 *** 作,请确保每个线程 *** 作的SQL语句中的表是相对独立的。 不然,你需要安排线程间的顺序,也就是lock代码段。 同一时间,两个线程一起跑同一句SQL,而且还 *** 作同一张表,那么,肯定就会有问题了。

一般这种是因为超出数据库最大链接上限。再建立链接,不管缓存多少,会自动队列消息等待。Timeout时间内没有链接取消无法获得链接权限。可以将自己的数据库链接个数设置大一些。

思路:

    1.按着自己需要的条件分给不同的线程进行查询,查询结束后,将返回的结果add到全局的List中。例:时间段查询,将时间进行分块,然后拼装成List集合

对于复杂的业务sql查询,可以考虑如下建议。

1.先通过sql查询出主表信息列表list.

2.for循环list,补充查询主表对应的子表信息。

3.在2的步骤中,可以使用多线程处理for查询。

SQL指结构化查询语言,SQL使我们有能力访问数据库,SQL是一种 ANSI 的标准计算机语言


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9895224.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存