인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

류재안님의 프로필 이미지
류재안

작성한 질문수

파이썬 웹 개발(Flask, SQLAlchemy 이용)

등록 웹 페이지 개발 2

(등록 웹 페이지 개발 3) relationship등록관련 경고문구

작성

·

169

0

안녕하세요.

강사님 내용대로 하면 계속 경고문구가 나오는데요.

이걸 변경해줘야 할 지요..

(경고문구)

Role.query.all()

back_populates 로 바꿔주면 경고는 사라집니다.

from flask_sqlalchemy import SQLAlchemy
from flask import Flask


app = Flask(__name__)
app.app_context().push()

app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:////ryujaean/study/flask_sqlalchemy/form_webapp/form_db'

db = SQLAlchemy(app)


# Role, Membr, Project

class Role(db.Model):
    id = db.Column(db.Integer, primary_key = True)
    position = db.Column(db.String(50))
    members = db.relationship('Member', backref='role', lazy = 'dynamic')

class Member(db.Model):
    id = db.Column(db.Integer, primary_key = True)
    name = db.Column(db.String(100))
    role_id = db.Column(db.Integer, db.ForeignKey('role.id'))
    # projects = db.relationship('Project', secondary='member_project', backref='member', lazy='dynamic')
    projects = db.relationship('Project', secondary='member_project', back_populates='members', lazy='dynamic')
    

class Project(db.Model):
    id = db.Column(db.Integer, primary_key = True)
    name = db.Column(db.String(100))
    # members = db.relationship('Member', secondary='member_project', backref='project', lazy='dynamic')
    members = db.relationship('Member', secondary='member_project', back_populates='projects', lazy='dynamic')
    

db.Table('member_project',
    db.Column('member_id',db.Integer, db.ForeignKey('member.id')),
    db.Column('project_id',db.Integer, db.ForeignKey('project.id'))
    )

 

답변 1

0

최광성님의 프로필 이미지
최광성
지식공유자

사용하는 flask 와 python 버전이 어떻게 ㄷ히나요?

류재안님의 프로필 이미지
류재안
질문자

python 3.10.10

flask 3.0.1

flask-SQLAlchemy 3.1.1

SQLAlchemy 2.0.25

입니다.

 >> goormIDE 에서도 동일한 경고가 나왔는데요. 거기의 버전은 아래와 같습니다.

flask 2.5.5

Flask-SQLAlchemy 3.0.5

Python 3.7.4

SQLAlchemy 2.0.25

그리고

현재 로컬pc에서, vscode로

Role.query.get() 코드 실행시,

결과값이 나오기는 하나 old 버전이고,

Session.get()을 실행하라는 경고문이 나오네요.

ㅡㅡ;;

>>>>>>

session.get()사용하라는 경고문은

editor = db.session.get(Role,2) 로 하니까 사라졌네요.

류재안님의 프로필 이미지
류재안

작성한 질문수

질문하기