name, job, and df_join all have separate Vector{Int64} for the ID column, they won’t share mutations. Even if leftjoin was able to make name and df_join share the ID vector, job still can’t share it because you provided a separate vector with different values in the first place.
You need to change types to pull off what you want. For example, you could make a Ref.([1, 2, 3]) for name’s ID column and very carefully reuse those elements in all subsequent Vector{Ref{Int64}}. The vectors still won’t be shared so you don’t mutate those, but you mutate the Ref element.
I don’t recommend doing this everywhere because linking elements like this gets really messy. You could change a value that conflicts with another row, and that’s much easier to accidentally do when you’re mutating something in several tables at once. If you’re just mutating Ref instances, separate instances can end up referencing the same value, so you can’t be sure one Ref(999) is the same as the other Ref(999) when printed. I guess you could check a cache and mutate the vector’s element to an existing referenced value instead of mutating the reference every time, but that’s complicated to pull off and track too, and irreversibly decreasing the number of unique elements like that may not even be desirable. Making many Ref elements also hurts performance in general because of the lack of data locality in memory.