summaryrefslogtreecommitdiff
path: root/shopdb/_associations.py
blob: e0e25bf05259f3a17b67b198849fc9b9042a2718 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
from sqlalchemy import Column, Integer, String, Table
from sqlalchemy.orm import relationship
from sqlalchemy import ForeignKey
from ._base import Base
from ._customer import Customer
from ._group import Group
from ._job import Job


customer_group = Table('customer_group', Base.metadata,
    Column('customer_id', Integer, ForeignKey('customers.id')),
    Column('group_id', Integer, ForeignKey('groups.id'))
)
Customer.groups = relationship("Group", secondary=customer_group, back_populates="members")
Group.members = relationship("Customer", secondary=customer_group, back_populates="groups")



customer_job = Table('customer_job', Base.metadata,
    Column('customer_id', Integer, ForeignKey('customers.id')),
    Column('job_id', Integer, ForeignKey('jobs.id'))
)
Customer.jobs = relationship("Job", secondary=customer_job, back_populates="customers")
Job.customers = relationship("Customer", secondary=customer_job, back_populates="jobs")