employee, job, payment的数据库设计

employee和job之间的relationship是many to many,一个employee可以有多个工作,一个工作也可以有几个人干。现在有一个associate table employeejob来表示many to many。还有一个payment table用来表示一个人的一份工作的payment。所以employeejob和payment的ralationship是one to one。

class EmployeeJob(db.Model):
__tablename__ = 'employeejob'
employee_id = db.Column(db.Integer, db.ForeignKey('employee.id'))
job_id = db.Column(db.Integer, db.ForeignKey('jobs.id'))
# payment_id = db.Column(db.Integer, db.ForeignKey('payment.id'))

不是很确定是不是应该把payment加到EmployeeJob里。

阅读 3.1k
2 个回答

应该放到EmployeeJob里,你的EmployeeJob拥有自己的属性,不完全是关联表,本身是一个实体了。
最好把名字改一下,比如改成Task。

Employee (EmployeeId PK, FirstName, LastName)
Job (JobId PK, Description)
Task (EmployeeId PK FK1, JobId PK FK2, Payment)

如果employee 的某一个job支持多次Payment,那么payment还是新建一个job payment结构(表)
包含payment_id,employee_id,job_id

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题