When encountering the “Multiple levels of many-to-one relationship expansion aren’t supported” message in a canvas app, here are the cause and solution.
Accessing Parent Records
When working with Dataverse in canvas apps, you can access parent table information using the “.” (dot) notation.
data:image/s3,"s3://crabby-images/75726/75726cafd85eecfcf75ee592257f2b2e9d0884cc" alt=""
data:image/s3,"s3://crabby-images/2afa1/2afa18fb1b3dcf3ec408b2b4530317c51d869071" alt=""
data:image/s3,"s3://crabby-images/ab39a/ab39ae29871ff45c5e6a78ae8e34b05205e3a582" alt=""
While this is quite convenient, attempting to access the parent’s parent table results in the error “Multiple levels of many-to-one relationship expansion aren’t supported”.
Multiple Level Expansion
data:image/s3,"s3://crabby-images/58cef/58cef320b57bbf87216b898be2dd07a1b3e33ff3" alt=""
data:image/s3,"s3://crabby-images/a1d27/a1d277fbec997ad1a76c0e49f17a403362f1362a" alt=""
Unfortunately, the “.” notation can only access one level up in the table hierarchy, so let’s explore some workarounds.
Solution 1: Using the LookUp Function
The first solution is to use the LookUp function.
data:image/s3,"s3://crabby-images/3d5d2/3d5d2897b76447a9eaf72d8f6a1f16f0310a5f15" alt=""
data:image/s3,"s3://crabby-images/02782/02782f7d84c349dfc3757b55aeb0312e81d70083" alt=""
Solution 2: Using Formula Columns
data:image/s3,"s3://crabby-images/94b2f/94b2ff4c8c673c7e4d54d565eec99d95852f7aef" alt=""
The following information is outdated and for reference only.
+++ Legacy Article Start +++
Another solution is to add a calculated column to the “Cat” table.
data:image/s3,"s3://crabby-images/0ae14/0ae146bceab13d2506d1748f4331d52c4e233b1a" alt=""
data:image/s3,"s3://crabby-images/38b53/38b53c1e621c9a768f5db08dd6160eac14be457e" alt=""
data:image/s3,"s3://crabby-images/a1b16/a1b16ec8a7a7ceaf1e67ec5b4cb9103ebf58533f" alt=""
While using the LookUp function allows access to all parent information without adding new columns, it generates Dataverse access for each item when displayed in galleries, which might impact performance.
In contrast, using calculated columns requires adding columns for each piece of needed information (and only works with supported data types), but the parent access is handled by Dataverse (presumably), making it less likely to impact performance (presumably).
The choice between these methods depends on the specific situation.
Another option is to add a lookup column to the “Meal History” table referencing the “Owner” table, but this also creates data redundancy, so it’s situation-dependent.
コメント