-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathmodels.py
84 lines (56 loc) · 2.75 KB
/
models.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
# -*- coding:utf-8 -*-
__author__ = '东方鹗'
__blog__ = 'http://www.os373.cn'
from sqlalchemy import Column, Date, ForeignKey, Integer, String, create_engine
from sqlalchemy.orm import relationship, sessionmaker
from sqlalchemy.dialects.mysql.enumerated import ENUM
from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()
# metadata = Base.metadata
class Department(Base):
__tablename__ = 'departments'
dept_no = Column(String(4), primary_key=True)
dept_name = Column(String(40), nullable=False, unique=True)
class DeptEmp(Base):
__tablename__ = 'dept_emp'
emp_no = Column(ForeignKey('employees.emp_no', ondelete='CASCADE'), primary_key=True, nullable=False, index=True)
dept_no = Column(ForeignKey('departments.dept_no', ondelete='CASCADE'), primary_key=True, nullable=False, index=True)
from_date = Column(Date, nullable=False)
to_date = Column(Date, nullable=False)
department = relationship('Department')
employee = relationship('Employee')
class DeptManager(Base):
__tablename__ = 'dept_manager'
dept_no = Column(ForeignKey('departments.dept_no', ondelete='CASCADE'), primary_key=True, nullable=False, index=True)
emp_no = Column(ForeignKey('employees.emp_no', ondelete='CASCADE'), primary_key=True, nullable=False, index=True)
from_date = Column(Date, nullable=False)
to_date = Column(Date, nullable=False)
department = relationship('Department')
employee = relationship('Employee')
class Employee(Base):
__tablename__ = 'employees'
emp_no = Column(Integer, primary_key=True)
birth_date = Column(Date, nullable=False)
first_name = Column(String(14), nullable=False)
last_name = Column(String(16), nullable=False)
gender = Column(ENUM('M', 'F'), nullable=False)
hire_date = Column(Date, nullable=False)
class Salary(Base):
__tablename__ = 'salaries'
emp_no = Column(ForeignKey('employees.emp_no', ondelete='CASCADE'), primary_key=True, nullable=False, index=True)
salary = Column(Integer, nullable=False)
from_date = Column(Date, primary_key=True, nullable=False)
to_date = Column(Date, nullable=False)
employee = relationship('Employee')
class Title(Base):
__tablename__ = 'titles'
emp_no = Column(ForeignKey('employees.emp_no', ondelete='CASCADE'), primary_key=True, nullable=False, index=True)
title = Column(String(50), primary_key=True, nullable=False)
from_date = Column(Date, primary_key=True, nullable=False)
to_date = Column(Date)
employee = relationship('Employee')
# 初始化数据库连接:
engine = create_engine('mysql+pymysql://ousikongjian:{}@125.42.176.217:63306/employees'.format('hawk@#'), echo=True)
# 创建DBSession类型:
DBSession = sessionmaker(bind=engine)
session = DBSession()