I’m phrasing the question title poorly as I’m not sure what to call what I’m trying to do but it really should be simple.
I’ve a link / join table with two ID columns. I want to run a check before saving new rows to the table.
The user can save attributes through a webpage but I need to check that the same combination doesn’t exist before saving it. With one record it’s easy as obviously you just check if that attributeId is already in the table, if it is don’t allow them to save it again.
However, if the user chooses a combination of that attribute and another one then they should be allowed to save it.
Here’s an image of what I mean:

So if a user now tried to save an attribute with ID of 1 it will stop them, but I need it to also stop them if they tried ID’s of 1, 10 so long as both 1 and 10 had the same productAttributeId.
I’m confusing this in my explanation but I’m hoping the image will clarify what I need to do.
This should be simple so I presume I’m missing something.
If I understand the question properly, you want to prevent the combination of
AttributeIdandProductAttributeIdfrom being reused. If that’s the case, simply make them a combined primary key, which is by natureUNIQUE.If that’s not feasible, create a stored procedure that runs a query against the join for instances of the
AttributeId. If the query returns 0 instances, insert the row.Here’s some light code to present the idea (may need to be modified to work with your database):