data:image/s3,"s3://crabby-images/9a3dd/9a3ddbf0e76c814acba02611858cc8e9d0ad736b" alt="Howard_Cohen Howard_Cohen"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jan 28, 2025 04:21 PM
I have and “hours” table whose rows consist of the following relevant fields:
- An email address of an event participant
- Number of hours participation in an event
- Year of the event participation
There will be separate rows with the same email address for each event where hours are recorded.
I want to create a query (filter, group by,…) that answers this question. Which people (email address) participated in at least one event in both 2022 and 2023.
Following one suggestion, I
- Grouped the rows by email address
- Created a new field, called “yrs active” that is defined by the formula “arrayunique(year)”. On the email address group by line, it indicates the number of unique values found so I assumed I could apply formulas or filtering that operated on just those unique values.
- Created a second field, “In 2022 and 2023” defined by the formula, AND(FIND("2022", {Yrs Active}), FIND("2023", {Yrs Active}))thinking that at the group by level, if the unique values contained both 2022 and 2023, the logical formula would return True. But that did not work.
- I then tried filtering such that “yrs active” contains 2022 and 2023, but that resulted in 0 rows which qualified. But if I filter such that “yrs active” contains only 2022, then I get correct results. If I filter for 2022 or 2023, I get the correct selection.
Solved! Go to Solution.
Accepted Solutions
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jan 29, 2025 04:21 AM
Hi,
The formula not working because in a single table, records 'doesn't know' about each other. The common approach to all kind of 'vertical' totals, grouping, creating pivot table is - to create other linked table. There can be a lot of such tables including temporary..
You need to ungroup you table, then just duplicate email field and make it linked
In a new table, you can add Year as lookup and filter as you need
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jan 31, 2025 12:37 PM
Well, I just asked LLM to create a small table with email, hours and year.
I think you don't need to change anything.
But in cases like this you can't choose text format because data type and format are different things.
You need to explicitly convert numeric data into text or vise versa.
To get text data you can add another field with CONCATENATE({Lookup field}) - it will convert array to a text string. Or, in source table you can change formula. YEAR(DATE) is number , but YEAR(Date) & `` is text, just add empty string or wrap it into CONCATENATE()
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jan 29, 2025 04:21 AM
Hi,
The formula not working because in a single table, records 'doesn't know' about each other. The common approach to all kind of 'vertical' totals, grouping, creating pivot table is - to create other linked table. There can be a lot of such tables including temporary..
You need to ungroup you table, then just duplicate email field and make it linked
In a new table, you can add Year as lookup and filter as you need
data:image/s3,"s3://crabby-images/9a3dd/9a3ddbf0e76c814acba02611858cc8e9d0ad736b" alt="Howard_Cohen Howard_Cohen"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jan 29, 2025 07:39 AM
Thank you Alexey - I was able to follow your explanation and the solution worked. The only peculiarity was that your where clause used the "contains" operator, but I was not given that option. When I added filters for "year lookup", my only options were logical operators such as ==,>,<, empty, etc. I thought perhaps this is due to something be a number versus text but was not sure? I attached a screenshot of the filter drop down and the year lookup field
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jan 29, 2025 11:50 PM
Yes, you are right. Lookup is computed field and it depends on format in source table. I intentionally made the Year field in text format, because I wasn't sure how to filter 2 different years with "=". But as we can see, in Lookup, '=' works in the same way as 'contains'.
data:image/s3,"s3://crabby-images/9a3dd/9a3ddbf0e76c814acba02611858cc8e9d0ad736b" alt="Howard_Cohen Howard_Cohen"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jan 31, 2025 08:37 AM
Thanks for confirming; helps me to improve my airtable proficiency. It is curious to me that "is" or "=" works since the lookup is a kind of list or array of values and those operators would suggest an exact match to the entire list rather than "contains". Anyway, I tried to duplicate what you did, but when I try to change the format of the "year" field it does not provide "text" as an option. The Year field in the original table was actually a formula that extracts year from a date (see screenshot attached) and I could not find a way to make either that field or the field in the copied table a text field
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jan 31, 2025 12:37 PM
Well, I just asked LLM to create a small table with email, hours and year.
I think you don't need to change anything.
But in cases like this you can't choose text format because data type and format are different things.
You need to explicitly convert numeric data into text or vise versa.
To get text data you can add another field with CONCATENATE({Lookup field}) - it will convert array to a text string. Or, in source table you can change formula. YEAR(DATE) is number , but YEAR(Date) & `` is text, just add empty string or wrap it into CONCATENATE()
data:image/s3,"s3://crabby-images/79abb/79abbc03cc624ea7bc441501b499dd398789db84" alt=""