RICHEER COCA 2022-05-29 15:45 采纳率: 93.9%
浏览 26
已结题

请问如何开20个线程 执行以下这个SQL脚本?

SQL SERVER 2019的A_CENTER数据库里有个表QY_FRID_K10
请问如何开20个线程 执行以下这个SQL脚本?


DECLARE @times INT = 0; 
DECLARE @GroupID INT = 1;
DECLARE @Result TABLE(GroupId INT,WID INT, KID VARCHAR(5))
 
Start:
    DROP TABLE IF EXISTS #Result;
    DECLARE @Top10To15 INT=RAND()*3+12

    SELECT TOP(@Top10To15) WID,QY_RID,WValue,WNO,QY_FAID,TWO_ALL,SIX_ALL,XieLian,YanXu,BzwBALL,BuQue,DanQI,F_NOO
    INTO #Result 
    FROM [A_CENTER]..[QY_FRID_K10] WHERE WValue BETWEEN 2 AND 8 ORDER BY NEWID()

    INSERT #Result ( WID,QY_RID,WValue,WNO,QY_FAID,TWO_ALL,SIX_ALL,XieLian,YanXu,BzwBALL,BuQue,DanQI,F_NOO)
    SELECT  TOP (20 - @Top10To15)  WID,QY_RID,WValue,WNO,QY_FAID,TWO_ALL,SIX_ALL,XieLian,YanXu,BzwBALL,BuQue,DanQI,F_NOO FROM [A_CENTER]..[QY_FRID_K10] WHERE WValue NOT BETWEEN 2 AND 8 ORDER BY NEWID();
 
        IF EXISTS (   SELECT    1
                  FROM      #Result
                  HAVING    SUM(CASE WHEN QY_RID = 'A1' THEN 1 ELSE 0 END) BETWEEN 10 AND 10
                            AND SUM(CASE WHEN QY_RID = 'B1' THEN 1 ELSE 0 END) BETWEEN 5 AND 5
                            AND SUM(CASE WHEN QY_RID = 'C1' THEN 1 ELSE 0 END) BETWEEN 5 AND 5

                            AND SUM(CASE WHEN QY_FAID = 'F1' THEN 1 ELSE 0 END) BETWEEN 8 AND 8
                            AND SUM(CASE WHEN QY_FAID = 'S1' THEN 1 ELSE 0 END) BETWEEN 5 AND 5
                            AND SUM(CASE WHEN QY_FAID = 'T1' THEN 1 ELSE 0 END) BETWEEN 2 AND 2
                            AND SUM(CASE WHEN QY_FAID = 'L1' THEN 1 ELSE 0 END) BETWEEN 5 AND 5                            
                            )     
        BEGIN
            INSERT @Result (GroupId, WID, KID)        
            SELECT @GroupID, WID, 'N' + CAST(ROW_NUMBER() OVER (ORDER BY WID) AS VARCHAR(5)) AS KID FROM  #Result;
            SET @GroupID=@GroupID+1;
            IF @GroupID>5
                BEGIN
                INSERT INTO [WIN28b]..[Result_WIN28b]  --  SELECT * FROM [WIN28b]..[Result_WIN28b];
                    SELECT *   FROM  @Result PIVOT (MIN(WID) FOR KID IN (N1,N2,N3,N4,N5,N6,N7,N8,N9,N10,N11,N12,N13,N14,N15,N16,N17,N18,N19,N20)) p
                    RETURN
                END
            ELSE
                GOTO Start;
        END;
    ELSE
        GOTO Start;
  • 写回答

1条回答 默认 最新

  • 笑看风云路 大数据领域优质创作者 2022-05-31 08:15
    关注

    可以使用java创建多线程,连接MySQL数据库,去执行你的SQL语句!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 9月19日
  • 已采纳回答 9月11日
  • 创建了问题 5月29日

悬赏问题

  • ¥15 smptlib使用465端口发送邮件失败
  • ¥200 总是报错,能帮助用python实现程序实现高斯正反算吗?有偿
  • ¥15 对于squad数据集的基于bert模型的微调
  • ¥15 为什么我运行这个网络会出现以下报错?CRNN神经网络
  • ¥20 steam下载游戏占用内存
  • ¥15 CST保存项目时失败
  • ¥15 树莓派5怎么用camera module 3啊
  • ¥20 java在应用程序里获取不到扬声器设备
  • ¥15 echarts动画效果的问题,请帮我添加一个动画。不要机器人回答。
  • ¥15 Attention is all you need 的代码运行