Есть ли причина, по которой вызов простой хранимой процедуры через Tedious занимает так много времени? - PullRequest
0 голосов
/ 30 апреля 2019

Я заметил, что при вызове простой хранимой процедуры CreateStatusReport, которая просто вставляет в таблицу INSERT, часто требуется необычно много времени для выполнения, которое я (к лучшему или худшему) предполагаю, что связано с некоторыми TDS или, возможно, так, как я это называю.

Вот код TDS, который вызывается в REST API Node.js:

function createReport(req, res) {
    let isReleased = false;

    let connection = new Connection(config);  

    connection.on('connect', function(err) {  
        let sql = "CreateStatusReport";

        if (err) console.log("**CN-ERROR", err);

        let request = new Request(sql, (err)=>{
            if (err) {
                console.log("**RQ-ERROR**", err);
            }
        });

        // Check to see if user clicked the "Release" button...
        if (typeof req.body.release != 'undefined')
            isReleased = true;

        request.addParameter('empid', TYPES.NVarChar, req.body.empid);
        request.addParameter('userid', TYPES.NChar, req.body.userid);
        request.addParameter('firstname', TYPES.NVarChar, req.body.fname);
        request.addParameter('lastname', TYPES.NVarChar, req.body.lname);
        request.addParameter('title', TYPES.NVarChar, req.body.title);
        request.addParameter('cabinet', TYPES.NVarChar, req.body.cabinet);
        request.addParameter('office', TYPES.NVarChar, req.body.office);
        request.addParameter('division', TYPES.NVarChar, req.body.division);
        request.addParameter('branch', TYPES.NVarChar, req.body.branch);
        request.addParameter('perstart', TYPES.VarChar, req.body.periodStart);
        request.addParameter('perend', TYPES.VarChar, req.body.periodEnd);
        request.addParameter('status', TYPES.NVarChar, req.body.status);
        request.addParameter('needs', TYPES.NVarChar, req.body.needs);
        request.addParameter('goals', TYPES.NVarChar, req.body.goals);
        request.addParameter('concerns', TYPES.NVarChar, req.body.concerns);
        request.addParameter('released', TYPES.Bit, isReleased);

        connection.callProcedure(request);

        request.on("requestCompleted", ()=> {
            res.redirect("/kudos")    
        });
    });  
}

Хранимая процедура очень проста, поэтому я просто добавлю сюда "кишки":

INSERT INTO [status-report] (empid, [userid], firstname, lastname, title,[cabinet], [office], [division], [branch], [period-start], [period-end], [date-posted], [status], needs, goals, concerns, released) 
VALUES (@empid, @userid, @firstname, @lastname, @title, @cabinet, @office, @division, @branch, @perstart, @perend, GETDATE(), @status, @needs, @goals, @concerns, @released)

Для создания записи в системе может потребоваться до нескольких секунд, и я не знаю, почему, поскольку система находится в высокопроизводительной производственной системе.

Есть ли здесь некоторые вещи, которые я пропускаю? Любые предложения относительно того, как я могу найти основную причину?

Заранее спасибо!

UPDATE

USE [kudos]
GO

/****** Object:  StoredProcedure [dbo].[GetList]    Script Date: 5/1/2019 4:39:50 PM ******/
SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

-- =============================================
-- Author:      <Author,,Name>
-- Create date: <Create Date,,>
-- Description: <Description,,>
-- =============================================
ALTER PROCEDURE [dbo].[GetList]
AS
BEGIN
    SET NOCOUNT ON

    SELECT 
        [id],
        [empid],
        [lastname] + ', ' + [firstname] AS [name],
        LTRIM(RTRIM([userid])) AS [userid],
        [title],
        [cabinet],
        [office],
        [division],
        [branch],
        CONVERT(nvarchar(10), [period-start], 110) AS [periodstart],
        CONVERT(nvarchar(10), [period-end], 110) AS [periodend], 
        CONVERT(nvarchar(10), [date-posted], 110) AS [dateposted],
        IIF(released = 1, 'Released', 'In Progress') AS [released]
    FROM 
        [status-report] 
    WHERE 
        [date-posted] BETWEEN GETDATE() - 21 AND GETDATE() 
    ORDER BY 
        [date-posted] DESC
END
GO

1 Ответ

0 голосов
/ 21 мая 2019

Это была ошибка ID10T (моя).В производстве есть балансировщик нагрузки.Иногда вызов был сделан, иногда не потому, что код не был синхронизирован в обеих системах.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...