inflearn logo
강의

講義

知識共有

Python Web開発(Flask、SQLAlchemyを使用)

登録ウェブページ開発 2

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

287

pink321ryu

投稿した質問数 58

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'))
    )

 

python flask sqlalchemy

回答 1

0

kwangsung

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

0

pink321ryu

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) 로 하니까 사라졌네요.

작업형 1 유형 부분

0

9

1

수강평 이벤트

0

16

2

작업형 1 (삭제예정, 구 버전)

0

28

2

강의노트는 어디있나요?

0

17

1

노션 학습 자료 권한 요청

0

15

1

수강기간 연장 문의드립니다.

0

20

1

2유형 레이블 인코딩 VS 원핫 인코딩

0

22

3

part2강의 문의사항입니다.

0

19

2

수강기간 연장 문의드립니다.

0

26

1

(many to many)에러문구 관련

0

368

1

(one-to-many) admin.users.all() 시 출력화면

0

377

1

[db, model2] inflearn 테이블 생성오류시 참고하세요.

0

255

1

use inflearn;

0

313

1

공유 템플릿

0

344

1

run이 작동이 안됩니다ㅠㅠ

0

276

1

서버를 열었을때 404 오류가 납니다

0

277

1

실습 중 질문이 있습니다.

0

555

3

BluePrint 질문입니다.

0

321

1

Project.query.get(1) 질문

0

359

2

db, model2에서 db.create_all()수행시 나타나는 오류입니다..

0

528

1

sql db중에 id 1의 정보가없습니다

0

290

1

relationship 코드위치.

0

167

1

ForeignKey 에러 관련.

0

241

3

Delete가아니고 Update강의가 올라와있네요

0

221

2