Отсутствует содержимое поля CreatorFullName и ModifierFullName в GeneralJournalEntryLines

Бизнес-объект GeneralJournalEntryLines содержит строки транзакций GL Exact Online. По причинам настройки производительности мы меняем наши сценарии, которые копируют данные из Exact Online в нашу локальную базу данных, чтобы они включали только изменения, где это возможно, вместо полной копии.

Однако запрос к GeneralJournalEntries, объединенный с GeneralJournalEntryLines, иногда возвращает нулевое значение в CreatorFullName и ModifiedFullName.

Я пытался воспроизвести новые строки с этой проблемой, но они работают нормально.

Это повреждение базы данных? Или ошибка соединения на моей стороне?

Точный онлайн запрос:

use <DIVISION CODE>

select GE.Created GE_Created
      ,GE.Division GE_Division
      ,GE.EntryID GE_EntryID
      ,GE.EntryNumber GE_EntryNumber
      ,GE.FinancialPeriod GE_FinancialPeriod
      ,GE.FinancialYear GE_FinancialYear
      ,GE.JournalCode GE_JournalCode
      ,GE.Modified GE_Modified
      ,GE.Reversal GE_Reversal
      ,GE.Status GE_Status
      ,GE.Type GE_Type
      ,GL.AccountCode GL_AccountCode
      ,GL.AmountDC GL_AmountDC
      ,GL.AmountVATDC GL_AmountVATDC
      ,GL.AssetCode GL_AssetCode
      ,GL.CostCenter GL_CostCenter
      ,GL.CostUnit GL_CostUnit
      ,GL.CreatorFullName GL_CreatorFullName
      ,GL.Date GL_Date
      ,GL.Description GL_Description
      ,GL.GLAccountCode GL_GLAccountCode
      ,GL.LineNumber GL_LineNumber
      ,GL.ModifierFullName GL_ModifierFullName
      ,GL.OurRef GL_OurRef
      ,GL.ProjectCode GL_ProjectCode
      ,GL.Quantity GL_Quantity
      ,GL.VATBaseAmountDC GL_VATBaseAmountDC
      ,GL.VATCode GL_VATCode
      ,GL.VATPercentage GL_VATPercentage
      ,GL.VATType GL_VATType
from       ExactOnlineREST..GeneralJournalEntries GE
inner join ExactOnlineREST..GeneralJournalEntryLines GL
on GE.EntryID=GL.EntryID
where GE.Status <> 50 
or ( GE.Status = 50 and ( (GE.FinancialYear*100) + GE.FinancialPeriod = 201501 and GE.Modified > '09/01/2017 14:03:09' ) ) 
or ( GE.Status = 50 and ( (GE.FinancialYear*100) + GE.FinancialPeriod = 201502 and GE.Modified > '09/01/2017 14:03:09' ) ) 
or ( GE.Status = 50 and ( (GE.FinancialYear*100) + GE.FinancialPeriod = 201503 and GE.Modified > '09/01/2017 14:03:09' ) ) 
or ( GE.Status = 50 and ( (GE.FinancialYear*100) + GE.FinancialPeriod = 201504 and GE.Modified > '09/01/2017 14:03:09' ) ) 
or ( GE.Status = 50 and ( (GE.FinancialYear*100) + GE.FinancialPeriod = 201505 and GE.Modified > '09/01/2017 14:03:08' ) ) 
or ( GE.Status = 50 and ( (GE.FinancialYear*100) + GE.FinancialPeriod = 201506 and GE.Modified > '09/01/2017 14:03:08' ) ) 
or ( GE.Status = 50 and ( (GE.FinancialYear*100) + GE.FinancialPeriod = 201507 and GE.Modified > '09/01/2017 14:27:27' ) ) 
or ( GE.Status = 50 and ( (GE.FinancialYear*100) + GE.FinancialPeriod = 201508 and GE.Modified > '09/01/2017 14:27:27' ) ) 
or ( GE.Status = 50 and ( (GE.FinancialYear*100) + GE.FinancialPeriod = 201509 and GE.Modified > '09/01/2017 14:27:27' ) ) 
or ( GE.Status = 50 and ( (GE.FinancialYear*100) + GE.FinancialPeriod = 201510 and GE.Modified > '09/01/2017 14:27:26' ) ) 
or ( GE.Status = 50 and ( (GE.FinancialYear*100) + GE.FinancialPeriod = 201511 and GE.Modified > '09/01/2017 14:27:27' ) ) 
or ( GE.Status = 50 and ( (GE.FinancialYear*100) + GE.FinancialPeriod = 201512 and GE.Modified > '09/01/2017 14:27:26' ) ) 

local export results as "D:\Invantive\data\uit_EOL\40570GeneralJournals.csv" format csv

local exit

1 ответ

Решение

При использовании запроса:

select * 
from   ExactOnlineREST..GeneralJournalEntryLines GL
where  gl.modifierfullname is null or gl.creatorfullname is null

кажется, что все строки, где modifiedfullname или же creatorfullname отсутствует связанный с ним GUID пользователя из короткого списка. Это также (на основе даты создания) все записи, которые имеют значительный возраст.

Похоже, что API Exact Online внутренне создают левое внешнее соединение с таблицей пользователей, для которого более активные пользователи не возвращают никакой информации.

Другие вопросы по тегам