从单个表读取的多个微型服务或控制台应用程序

发布于 2025-01-25 02:31:16 字数 446 浏览 0 评论 0原文

我需要通过微服务从SQLServer表中读取数百万个记录,该微服务确实可以并行读取。每个实例化的微服务在同一DB的同一表上执行相同的读取操作。您可以用来避免复制记录的最佳方法是什么? 通过重复记录,我的意思是不处理 /收集已经由同一服务的其他实例收集 /处理的记录,

我可以使用此方法吗?从每个微服务中进行选择,例如:

BEGIN TRANSACTION;
SELECT ITEM_ID
FROM TABLE_ITEM
WITH(XLOCK, ROWLOCK)
WHERE ITEM_PRIORITY > 10 AND ITEM_CATEGORY = 'CT1' AND ITEM_STATUS = 'available' AND ROWNUM = 1;
UPDATE [locked item_id] SET ITEM_STATUS = 'unavailable';
COMMIT TRANSACTION;

I need to read millions of records from a sqlserver table through a microservice that does block reads in parallel. each instantiated microservice performs the same read operation on the same table of the same DB. what is the best approach you can use to avoid taking duplicate records?
By duplicate records I mean not to process / collect records that have already been collected / processed by other instances of the same service

Can I use this approach? make selections from each microservice such as the following:

BEGIN TRANSACTION;
SELECT ITEM_ID
FROM TABLE_ITEM
WITH(XLOCK, ROWLOCK)
WHERE ITEM_PRIORITY > 10 AND ITEM_CATEGORY = 'CT1' AND ITEM_STATUS = 'available' AND ROWNUM = 1;
UPDATE [locked item_id] SET ITEM_STATUS = 'unavailable';
COMMIT TRANSACTION;

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文