ошибка преобразования имени файла только в агенте SQL

#sql #sql-server #agent

#sql #sql-server #агент

Вопрос:

Итак, я выполняю хранимую процедуру через агенты в среде SQL Server Management Studio. Когда я запускаю свою хранимую процедуру в обычном режиме, она работает нормально, не возвращая ошибок, однако при запуске из агента она не запускается.

Моя хранимая процедура:

 USE [Sales]
GO
/****** Object:  StoredProcedure [dbo].[forecastprojSPChartDetailsForPlaInsert]    Script Date: 29/09/2016 12:50:32 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author:      <Author,,Name>
-- Create date: <Create Date,,>
-- Description: <Description,,>
-- =============================================
ALTER PROCEDURE [dbo].[forecastprojSPChartDetailsForPlaInsert] 
    -- Add the parameters for the stored procedure here
AS
BEGIN
    -- SET NOCOUNT ON added to prevent extra result sets from
    -- interfering with SELECT statements.
    SET NOCOUNT ON;
    SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;

                Select DISTINCT 

                 MIN(S.Id) As Id
               , S.DATE_DEL
               ,'0.00' AS Installation 
               , SD.ProjectNo
               , SHA.[Customer Name]
               , P2.[Project Name]
               , AD.ApplicationDate
               , AD.IssueOfPaymentNotice
               , AD.FinalDateForSubPayment
               , AD.ValuationDate
               , CF.Comment
               , CF.QsNotified
               , CF.AccountsNotified
               , CF.CallBackDate
               , CF.PaidAmount
               , CF.PrevPaidOtherTextBox
               , CF.ConfirmedFinalDate
               , CF.ConfirmedPaidDate
               , CF.RemovedCheck
               , CF.RemovedCheckComment
               , 'No' as SO
               , CF.ApplicationDateChanged

               ,datename(month,SC.DateOfSend)
               ,datename(month,S.Date_Del)
               ,datename(month,AD.ApplicationDate) 

                from SODDFD S 
                INNER JOIN SpecDetails SD ON SD.SrecId = S.Srecid 
                INNER JOIN SpecificationHeader SHA ON SD.QuoteNo = SHA.Qno 
                INNER JOIN Projects2 P2 ON P2.PID = SHA.PID 
                INNER JOIN SentContracts SC on SC.PID = P2.PID and SC.DD = '1'
                INNER JOIN ApplicationDates AD on SHA.PID = AD.PID 

                AND
                 CASE WHEN CONVERT(DATE,GETDATE(),103) > CONVERT(DATE,AD.ApplicationDate,103) THEN datename(month,SC.DateOfSend)
                 ELSE datename(month,S.Date_Del)
                 END = datename(month,AD.ApplicationDate) 

                LEFT OUTER JOIN SentappDetails SA ON SA.SrecId = SD.SrecId 
                LEFT JOIN CashFlowProjectionTbl CF on AD.PID = CF.PID and AD.ApplicationDate = CF.ApplicationDate

               where 
                S.PID in (Select distinct PID from ApplicationDates) AND
                S.Id <> 0 AND
                S.Id <> '' AND
                Nominal = CASE WHEN SD.NewSellingPrice IS NULL THEN Nominal ELSE 'S001' END AND
                s.DATE_DEL <> ''AND
                (AD.ApplicationDate like '%/2016' or ConfirmedFinalDate <> '' or ConfirmedFinalDate IS NOT NULL)
                and (convert(date,IssueOfPaymentNotice,103) >= '01/05/2016' or ConfirmedFinalDate <> '' or ConfirmedFinalDate IS NOT NULL)
                --and (Cf.PaidAmount = '0' or Cf.PaidAmount = '0.00' or Cf.PaidAmount = '' or Cf.PaidAmount is NULL) 
                and (RemovedCheck = '' or RemovedCheck is NULL)
                and convert(date,Ad.ApplicationDate,103) >= '01/06/2016' 


                GROUP BY   S.PID, SD.NewSellingPrice, s.DATE_DEL, SA.CURR_APP, s.DEL_QTY, Comment, QsNotified, AccountsNotified,
                CASE WHEN SD.NewSellingPrice IS NULL THEN S.Id END ,SD.ProjectNo, SHA.[Customer Name], P2.[Project Name], 
                AD.ApplicationDate, ad.IssueOfPaymentNotice, AD.FinalDateForSubPayment, CF.CallBackDate,  
                CF.PaidAmount   , CF.PrevPaidOtherTextBox, CF.ConfirmedFinalDate, AD.ValuationDate, CF.ConfirmedPaidDate, CF.RemovedCheck, CF.RemovedCheckComment, CF.ApplicationDateChanged
                   ,datename(month,SC.DateOfSend)
               ,datename(month,S.Date_Del)
               ,datename(month,AD.ApplicationDate) 


    END
  

Когда это выполняется из моего агента, он не возвращает эту ошибку:

введите описание изображения здесь

Однако, если я заменю:

         AND
         CASE WHEN CONVERT(DATE,GETDATE(),103) > CONVERT(DATE,AD.ApplicationDate,103) THEN datename(month,SC.DateOfSend)
         ELSE datename(month,S.Date_Del)
         END = datename(month,AD.ApplicationDate) 
  

С:

         AND
         CASE WHEN CONVERT(DATE,GETDATE(),103) > CONVERT(DATE,AD.ApplicationDate,103) THEN 'July'
         ELSE 'July'
         END = 'July'
  

… он работает нормально.

Единственное, что я могу думать, это то, что в моих преобразованиях «DATENAME» возникает ошибка при запуске из моего агента. Принимая во внимание дату, которую я передаю:

  • SC.DateOfSend
  • S.Date_Del
  • AD.ApplicationDate

все они имеют формат dd / MM / yyyy.

Мне было интересно, может ли кто-нибудь помочь мне или посоветовать, что делать, поскольку я застрял на этом в течение нескольких часов. Заранее спасибо.

Комментарии:

1. Можете ли вы добавить ошибку?

2. Есть ли ошибки t-sql в журнале сервера после запуска агента?

3. см. Отредактированный вопрос. @AlexK.

4. см. Отредактированный вопрос. @alex

5. Это будет проблемой, связанной с форматами дд / мм / гг и гг / мм / дд даты. При указании буквенных дат в строке используйте независимый формат, например ISO yyyy / mm / dd, и убедитесь, что столбцы являются датами.

Ответ №1:

Вам необходимо изменить язык сервера по умолчанию или язык вашего входа по умолчанию

 SELECT @@LANGUAGE 
  

Функция DATENAME зависит от языка

 SET LANGUAGE us_english
  

Попробуйте записать в начале, а в конце снова установите его как есть

 declare @language as varchar(100)
SELECT @language= @@LANGUAGE 

SET LANGUAGE us_english 

--... your code...

SET LANGUAGE @language
  

Комментарии:

1. Значит, мой агент sql работает на другом языке для моего пользователя?

2. Я использовал SET LANGUAGE British, очень признателен.