Help

Re: Noobie question: I need help from airtable experts, Currently I'm not able to followup on my leads properly

2173 1
cancel
Showing results for 
Search instead for 
Did you mean: 
Jay_P
7 - App Architect
7 - App Architect

Currently, I have my data in multiple tables (20)
Each table has the exact same table structure. Please dont tell me to put all data in same table. I can’t do it.

& I don’t get much time to go into each and every table to check which leads I have to followup on.

I need a way by which I can view all the records that have the status ‘Negotiation State’ in all the tables to be displayed in one place so I can be more efficient with my work.

I make chnage in this view and the chnage should be implemented at the original table.

I see in other softwares like Asanas the pipeline thing is built in. How can i make my airtables more efficient ?

56 Replies 56

Its shameful that this is going to be tricky because in my view this is a basic requirement for users to manage multiple tables which & air tables should have provided out of box solution for this.

Well under the hood, its a very simple thing,

  1. In following records.
  2. Find records that have status flag equal to ‘Negotiation’
  3. Display them in the view/ Table.

I don’t think the resulting view even have to have same table structure. Just show the result how ever it is.

@Jason Do you have plans to provide this feature out of box anytime soon ?

I think the tricky part would be dealing with changes to the data in the original tables other than setting the {Status} to “Negotiation State”. How will any additional changes to the original record be propagated to the the “working” table? How will the automation know which existing record in the working table record to update? It could be done with a series of linked records or another field to store the “working” record ID. But it would have to be done with a script since automations currently don’t have a “find” action or an “if”.

A deeper problem would be changing the record out of the “Negotiation State”, which could theoretically happen from either table. When the “working” record changes out of the “Negotiation State”, it would need an automation to update the “source” record and delete itself. The source record would also need an automation to delete the working record when its state is changed. But what happens when the working record triggers the automation update the source record and delete itself? Then the source record would have a state change and want to run its automation because the automation can’t tell if the trigger was a human data change or the result of a previous automation. Then that automation script would need to deal with the fact that the working record that it wants to delete might already be deleted. So, while it is all possible, the code involved to protect the data integrity is not worth the trouble.

On another note, currently the only way to delete a record with an automation is with an action script. So, I guess my earlier comment about being able to do it with 20+ automations each way (40 total) would need an additional step of having a filtered view in the working table to hide all the old, no-longer-valid records.

This doesn’t even take into consideration the limits on the number of automation runs per month. The free plan allows only 100 automations per month and doesn’t allow scripting actions. Each record would require at least 2 automations (one to copy it to the working table another to copy it back to the source). So that’s 50 record changes in a month, which would be about 1-2 records to change per day. The plus plan has 5,000 runs per month, which would allow 50 times as many automations, and scripting automations. However, the total number of automation runs would be the same. So that’s about 50-100 records that could change per day, which still might not be enough depending on how many changes there are (including incremental changes to text fields and such).

ETA: There is a limit of 25 automations per base. So, having 40 automations (20 each way) won’t work.

Heres how out of box feature look like.

Its called favorites in Asana.

You can pick what you want & it shows you the results of it.

Using_search___advanced_search_in_Asana___Product_guide_·_Asana

Just here to clarify: Justin does not work for Airtable. He can’t provide this feature out of the box because he doesn’t work here (the badge and title “Community Leader” just means folks like Justin and I are here a lot).

If Kuovonne or Justin provide you the scripts described above its because you’ve paid them to write it or they were feeling charitable.

I’ve never used Asana, but to me, that looks very similar to creating a filter on a view. From what I see, they’re using a series of filters to create favorites from tasks, which (guessing) are in a single collection of all tasks, not spread across 20 different collections. Airtable’s views are essentially favorites: make them once, and then come back to them any time you want.

@Kamille_Parks I appreciate the clarification, but @Jay_P tagged Jason, not me. Not sure if Jay discovered elsewhere that Jason is an Airtable employee, or if it was simply a Justin/Jason mix-up (I get that a lot). My guess is that it’s the former, and Jay would like to know from someone on the inside if something like this is on the development roadmap.

To that point, Jay, Airtable staff have never revealed their development plans publicly. The only time we get advance knowledge of upcoming features is when they choose to release a beta. Sometimes that’s a public beta, other times it’s private to a select few, but in either case the feature is far enough along that the team has decided to pull back the curtain and let folks take it for a spin if they choose. All other features in development are not revealed until release.

Returning to your earlier comment about how you feel this is “a basic requirement for users,” I respectfully disagree. In your subject line, you admitted that you were a new Airtable user, and you asked in your opening post how to make your setup more efficient. All of my experience is that spreading similar data across multiple tables is inefficient, and I believe that others who have commented in this thread would back that up. There are very rare cases where having identical setups in multiple tables is actually necessary (I ran into one about a week ago, but it’s the first one I’ve seen in the 18 months I’ve been using Airtable). More often than not, a user’s desire for similar data across multiple tables is a holdover from how other software is designed. When we clarify that Airtable is designed differently, and share the benefits of single-table design using views, most people see right away that a single table is far more efficient.

We’ve tried to come up with a way to make this work across your current multiple-table setup, but I think that the latest comment from @kuovonne makes it pretty clear that this is beyond “tricky.” Trying to bend Airtable to operate the way you want is a major technical challenge, with some limitations that literally can’t be overcome.

That takes me back to the single-table solution. If you need to make 50 views in that table, I don’t see how navigating those views would be much different than navigating 50 tables. You’re just scrolling through a vertical list on the side vs tabs at the top (and there are keyboard shortcuts to make that navigation even easier). More importantly, though, putting everything into a single table eliminates all of the technical hurdles we’ve been talking about.

If navigating 50 views still feels like it would be too cumbersome, here’s something to consider. Instead of making 50 views (one for each state), what if you had one view that you could easily switch between states? Most people think of manually modifying a view’s filter settings to change the records that it displays, but another option is to use a script. This view I’m talking about would only show records with certain data in a special field that this script would update. Run the script, pick a state, and the script updates all records to only show those from that state in that view. That keeps your view count low, and you still have the many, many benefits of having everything in a single table.

We’ve given you the best advice we know regarding efficient base design, and encouraged you to follow that design and learn how Airtable operates most efficiently. If you don’t want to follow that advice, then I’m not sure what else I can offer.

It appears I am blind. lol

Justin,

Yes it’s just like filters, but if I have that folder or link on the side, and the number of tasks in it.

I can quickly know how much work I need to do and get it done!

Otherwise the other option is to open my 40 views under 20 tables to work on it. Nobody wanna do that.

And thus I fail in delivering my projects on time.

It make huge diffence.

Jay

:100: - agree with this. Gut feel says this will work in a single table. I’m sure the different priorities by state could be accommodated too. Maybe this isn’t the case, but haven’t seen an example where a single table for a single entity isn’t a better option.

@JonathanBowen and @Justin_Barrett in my travels the only times I can recall in which it made sense to split up things of the same ‘type’ into multiple tables where the field structure was the same in each table, was if the answer to the question “Why not use one table” was “I want finer control over field/record editing permissions”. That doesn’t appear to be the case here.

I have been following this thread because it has shown some weaknesses (and oddly, some nice strengths) of Airtable but more important - the weaknesses of specific design and data architecture choices.

We often believe that physical organizations are easier to understand and therefore, should be easier to implement. However, @Justin_Barrett’s deep commentary makes it clear that in this case, a physical differentiation between state leads not only creates a few (if not many) unintended constraints but it is woefully inefficient.

I agree with @Justin_Barrett and @JonathanBowen - this is clearly not a basic requirement and such requirement is rarely pursued across the constellation of database products, let alone Airtable.

However, there are cases where interstate commerce regulations require such organizations; I have no idea if this is one such case. But it would be worth noting to understand from @Jay_P the rigidity of the original source data collection constraints.

Indeed, no one should have to do that. However, if Airtable is the horse you desperately want to ride into the sunset, and these constraints are immovable, you best be carrying cash to a consultant who knows how to overcome these hurdles.

To this point, no one has thought to ask -

How are these original sources collected? Are they manually created via form? Are they imported? Are they generated in a unified data collection and then spun out into separate Airtable tables?

These questions might lead us to realize that Airtable is completely the wrong place to solve the notification challenges.

No one has mentioned scale - how much larger is the 20 original source tables likely to grow towards and how will that impact any given approach that already shows automation at the ceiling.

Yet another point - as I mentioned above, we tend to think of physical (not logical) data collections. With specific deference to the requirements, it may be worth thinking about simply an event architecture that “logs” records that point to leads that need to be visited; you don’t need the entire record to know that something important needs to be attended to. You only need the reference to that record when it meets criteria (i.e., a list of table/record IDs that lead you back to the actual data).

Lastly, there is not much distance between this problem domain and a search engine. What if you indexed all leads data as events occur and then used a search query?

Fascinating conversation.