Hello
Consider this example schema:
Customer ( int CustomerId pk, .... )
Employee ( int EmployeeId pk,
           int CustomerId references Customer.CustomerId, .... )
WorkItem ( int WorkItemId pk,
           int CustomerId references Customer.CustomerId,
           null int EmployeeId references Employee.EmployeeId, .... )
Basically, three tables:
- A customer table with a primary key and some additional columns
- A employee table with a primary key, a foreign key constraint reference to the customer tables primary key, representing an employee of the customer.
- A work item table, which stores work done for the customer, and also info about the specific employee who the work was performed for.
My question is. How do I, on a database level, test if an employee is actually associated with a customer, when adding new work items.
If for example Scott (employee) works at Microsoft (customer), and Jeff (employee) works at StackOverflow (customer), how do I prevent somebody from adding a work item into the database, with customer = Microsoft, and employee = Jeff, which do not make sense?
Can I do it with check constraints or foreign keys or do I need a trigger to test for it manually?
Should mention that I use SQL Server 2008.
UPDATE: I should add that WorkItem.EmployeeId can be null.
Thanks, Egil.