Department
& Ticket
テーブルの間に1対1の関係を作成しようとしています。 Flask-Admin
の内部を見ると、IDの代わりにDepartment
という名前が表示されます。1対1の関係を作成するFlask-SQLAlchemy
次のように私はセットアップに関係を試してみました:
# Ticket Table
class Tickets(db.Model):
__tablename__ = 'tickets'
ticketID = db.Column(db.Integer, nullable=False, primary_key=True, autoincrement=True, unique=True)
cust_name = db.Column(db.String(50), nullable=False)
cust_email = db.Column(db.String(50), nullable=False)
cust_phone = db.Column(db.Integer, nullable=False)
tix_dept = db.Column(db.Integer, db.ForeignKey('department.deptID'))
tix_severity = db.Column(db.Integer, nullable=False)
tix_msg = db.Column(db.String(500), nullable=False)
tix_status = db.Column(db.String(10), nullable=False)
tix_recv_date = db.Column(db.String(20), nullable=False)
tix_recv_time = db.Column(db.Integer, nullable=False)
# define relationship
department = db.relationship('Departments')
# Department Table
class Departments(db.Model):
__tablename__ = 'department'
deptID = db.Column(db.Integer, primary_key=True, autoincrement=True, unique=True)
dept_name = db.Column(db.String(40), nullable=False)
dept_empl = db.Column(db.String(40), nullable=False)
dept_empl_phone = db.Column(db.Integer, nullable=False)
はその後、私のFlask-Admin
見解は以下のとおりです。
admin.add_view(TicketAdminView(Tickets, db.session, menu_icon_type='glyph', menu_icon_value='glyphicon-home'))
admin.add_view(DepartmentAdminView(Departments, db.session))
管理パネルチケットのために:
どのように私はDepartment
名の代わりに、メモリ位置を示すに行きますか?
1対1については、http://stackoverflow.com/a/9611874/6085135 – brennan
を参照してください。 'department = db.relationship( 'Departments'、backref = backref(" tickets "、uselist = False))' uselist = Falseはあなたのビューの問題を同様に解決するかもしれません – brennan