inflearn logo
강의

Course

Instructor

Python Web Development (using Flask, SQLAlchemy)

Developing a registration web page 2

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

302

pink321ryu

58 asked

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

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

강의 자료

0

8

1

27:15 break 출력

0

11

1

kaggle notebook에 service key 설정이 누락된 것 같습니다

1

16

2

수업 노트가 안 보입니다.

0

19

1

Python formatter 설치

0

16

1

55강 파이썬에만있는 연산자들

0

22

2

55강의 파이썬에서만 있는 연산자들

0

20

2

주말에 실행할 경우 update_economic_data_in_background에 로직 변경 필요성

1

27

1

naver 글자 수집 오류 건

0

23

1

(many to many)에러문구 관련

0

380

1

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

0

391

1

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

0

263

1

use inflearn;

0

320

1

공유 템플릿

0

354

1

run이 작동이 안됩니다ㅠㅠ

0

288

1

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

0

289

1

실습 중 질문이 있습니다.

0

576

3

BluePrint 질문입니다.

0

329

1

Project.query.get(1) 질문

0

361

2

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

0

532

1

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

0

291

1

relationship 코드위치.

0

171

1

ForeignKey 에러 관련.

0

242

3

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

0

224

2