It would help to have a ROW_NUMBER function in FDGB SQL.
The ROW_NUMBER() is a window function that assigns a sequential integer to each row of a query’s result set. Rows are ordered starting from one based on the order specified by the ORDER BY clause in the window definition.
https://www.sqlitetutorial.net/sqlite-window-functions/sqlite-row_number/
Use cases:
I'm curious: Are you not able to pull the ObjectID field for this purpose?
The ObjectID is static. I want a dynamic row number within a sorted query.
Like this: Select the four largest cities.
objectid in (
    select
        objectid
    from
        (select
            objectid,
            row_number() over (order by population_2021 desc) as rownum 
        from
            cities)
    where
        rownum <= 4)This works in a mobile geodatabase. And there are enterprise geodatabase equivalents. But as far as I know, there isn't a function like ROW_NUMBER in file geodatabase SQL.
Or if window functions are too difficult to implement in FGDB SQL, then maybe a ROWNUM pseudo-column would work, similar to what Oracle does:
objectid in (
    select
        objectid
    from
        (select
            rownum, 
            objectid
        from
            cities
        order by
            population_2021 desc)
    where
        rownum <= 4)  
A ROW_NUM pseudo column would also help with Join — Control what related record gets used.
In a FGDB database view:
ORDER BY on the grouping ID/common ID field, then on the field that we want to prioritize for the one-to-first join, so that the desired row is at the top of each grouping. Reason: one-to-first joins use the related record that has the smallest object ID.
Replace the real OBJECTID field with a fake/new OBJECTID using ROW_NUM.
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.