Skip to main content
Question

SQL view doesn't return all records.


Forum|alt.badge.img

I created a simple SQL view for table INLocationStatus in customization "TestStockLogMasterInventoryReport"

 

Create VIEW [dbo].[LogoMasterInventoryReport]

AS

SELECT        TOP (100) PERCENT LS.CompanyID,  LS.InventoryID,  LS.SubItemID, LS.SiteID, LS.LocationID,

                     LS.QtyOnHand,   LS.QtyOnHand AS [TotalQtyonHand]

      

FROM        dbo.INLocationStatus AS LS

 

The table should have 212623 records. But the SQL view only returns 212213 records.

I created GI for INLocationStatus, and it return 212623 records. The GI for LogoMasterInventoryReport view only return 212213 records. 

Does anyone know there is any records restrictions for SQL view in Acumatica? This is for 2023 R2.

 

Thanks.

 

12 replies

dcomerford
Captain I
Forum|alt.badge.img+15
  • Captain I
  • 583 replies
  • January 12, 2024

Very strange but then Top (100) Percent is an oddity i presume you are trying to order the SQL view?

Can you try it removing the this and just use a straight Select and see how many records you are getting


Forum|alt.badge.img
  • Author
  • Varsity I
  • 26 replies
  • January 12, 2024

I removed it and use straight select, still the same.

 

Create VIEW [dbo].[LogoMasterInventoryReport]
AS
SELECT         LS.CompanyID,  LS.InventoryID,  LS.SubItemID, LS.SiteID, LS.LocationID,
                     LS.QtyOnHand,   LS.QtyOnHand AS [TotalQtyonHand]
      
FROM        dbo.INLocationStatus AS LS


dcomerford
Captain I
Forum|alt.badge.img+15
  • Captain I
  • 583 replies
  • January 12, 2024

Hmm ok anonther thought does yout GI based on table INLocationStatus have any other tables in the GI. If so remove them and check the result.


Forum|alt.badge.img
  • Author
  • Varsity I
  • 26 replies
  • January 12, 2024

We initially have group clause in the view and link multiple tables in the GI. We didn’t get the expected result. So I simplified view to just select fields without any group, and only include this view in GI without other tables. And I found the view doesn’t return all records.


dcomerford
Captain I
Forum|alt.badge.img+15
  • Captain I
  • 583 replies
  • January 12, 2024

I dont believe it is view that is the issue. I would trust it more than anything else. Can you tip both sets of results in to Excel and use a VLookup to find the extra/missings one.

The GI giving the result of 212623 does this only have one table in it the INLocationStatus


Forum|alt.badge.img
  • Author
  • Varsity I
  • 26 replies
  • January 12, 2024

Please see the screenshot below. The left screen is GI from the SQL view LogoMasterInventoryReport, that’s the only table in the GI. It has total 212213 records. The last record InventoryID stops at 19064.

The right screen is the GI from INLocationstatus inner join to InventoryItem. It has 212626 records. There are more records after InventoryID 19064. 

I don’t know why the SQL view stops at the InventoryID 19064.

 

 


dcomerford
Captain I
Forum|alt.badge.img+15
  • Captain I
  • 583 replies
  • January 15, 2024

@junmao01 Very weird would you mind sharing the GI with me and i will run it and the script on one of my datasets.


Forum|alt.badge.img
  • Semi-Pro II
  • 62 replies
  • January 15, 2024

@junmao01  This is going to sound counter-intuitive, but IMO, the issue is not your SQL view, but the GI with the INNER JOIN.
I think you are seeing too many rows returned in the INNER JOIN GI with the Inventory. (IE. you are returning duplicates in SQL in that GI).
What you might try is on your INNER JOIN GI, set grouping to LS.InventoryID and see then if the two GI’s return the same number of rows.  Or possibly using a LEFT JOIN instead.
What happens when you run those SQL commands natively in SSMS?
Below is an example where I took your SQL view statement and ran it against my DB natively, and then also ran it with an INNER JOIN on Inventory items.  You can see where the two SQL commands return different numbers of data sets.

IF you want to JOIN your INLocationStatus to your InventoryItem table as a SQL view, I have found it much better to use the following type of SQL construct. You can see the results in the third screenshot below.
    SELECT        TOP (100) PERCENT LS.CompanyID,  LS.InventoryID,  LS.SubItemID, LS.SiteID, LS.LocationID,
                                    LS.QtyOnHand,   LS.QtyOnHand AS [TotalQtyonHand],
                                    INV.[InventoryID],INV.[InventoryCD]
    FROM        dbo.INLocationStatus AS LS
    OUTER APPLY (
          SELECT TOP(1) *
          FROM [dbo].[InventoryItem]
          WHERE [dbo].[InventoryItem].[InventoryID] = LS.[InventoryID]
    ) INV
    WHERE LS.[CompanyID] = 2

 

 


Forum|alt.badge.img
  • Author
  • Varsity I
  • 26 replies
  • January 15, 2024

I don’t have any JOIN in my SQL view and GI. The SQL view is just select from one table INLocationStatus, and the GI only select this SQL view. This is in Acumatica sandbox. So I don’t have access to SSMS.


Forum|alt.badge.img
  • Author
  • Varsity I
  • 26 replies
  • January 16, 2024

I find the problem. From 2023 R2 the INSiteStatus and INLocationStatus are projection DAC now. The old records are still exist in the table. But new records will be added to actual table INSiteStatusByCostCenter and INLocationStatusByCostCenter. 


Robert Sternberg
Captain II
Forum|alt.badge.img+8

@junmao01 wow nice find, tricky one! 


Chris Hackett
Community Manager
Forum|alt.badge.img
  • Acumatica Community Manager
  • 2620 replies
  • January 16, 2024

Thank you for sharing your solution with the community @junmao01!


Reply


Cookie policy

We use cookies to enhance and personalize your experience. If you accept you agree to our full cookie policy. Learn more about our cookies.

 
Cookie settings