Python Flask Tutorial #4 - Database with Flask-SQLAlchemy > 파이썬

파이썬

그누 어디까지 써봤니? 나는 파이썬까지 써봤어!

Python Flask Tutorial #4 - Database with Flask-SQLAlchemy 정보

Python Flask Tutorial #4 - Database with Flask-SQLAlchemy

본문

https://youtu.be/cYWiDiIUxQc?list=PL-osiE80TeTs4UjLw5MM6OjgkjFeUxCYH

 

Flask-SQLAlchemy에 대해서 배웁니다.

 

https://flask-sqlalchemy.palletsprojects.com/en/2.x/

 

SQLAlchemy는 여러가지 데이타베이스를 지원합니다.  

https://docs.sqlalchemy.org/en/13/core/engines.html

 

PostgreSQL

MySQL

Oracle

Microsoft SQL Server

SQLite

 

몽고 DB는 별도로 지원합니다. https://pythonhosted.org/Flask-MongoAlchemy/

 

```

pipenv install flask-sqlalchemy

```

 

> pipfile에 제대로 등록되어 있는지 체크하세요

 

```

app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///site.db'

app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = True

db = SQLAlchemy(app)

 

class User(db.Model):

    id = db.Column(db.Integer, primary_key=True)

    username = db.Column(db.String(20), unique=True, nullable=False)

    email = db.Column(db.String(120), unique=True, nullable=False)

    image_file = db.Column(db.String(20), nullable=False, default='default.jpg')

    password = db.Column(db.String(60), nullable=False)

    posts = db.relationship('Post', backref='author', lazy=True)

 

    def __repr__(self):

        return f"User('{self.username}', '{self.email}', '{self.image_file}')"

 

class Post(db.Model):

    id = db.Column(db.Integer, primary_key=True)

    title = db.Column(db.String(100), nullable=False)

    date_posted = db.Column(db.DateTime, nullable=False, default=datetime.utcnow)

    content = db.Column(db.Text, nullable=False)

    user_id = db.Column(db.Integer, db.ForeignKey('user.id'), nullable=False)

 

    def __repr__(self):

        return f"Post('{self.title}', '{self.date_posted}')"

```

 

현재 디렉토리에 site.db라는 sqlite파일이 만들어집니다.  

 

테이블은 2개 user, post

 

https://sqlitebrowser.org/   로 확인해보면

 

1808292852_1575603769.9969.png

 

python을 실행해서 Command라인에서 바로 입력해서 확인하니 좋네요..

 

user와 post의 관계는 one to many  관계입니다.

 

User 는 many Post를 가질수 있고,  Post는 one User만 있게 됩니다.

 

https://www.youtube.com/watch?v=juPQ04_twtA

 

Relationship에서 lazy 옵션이 있는데,  이것에 대한 설명

 

https://www.youtube.com/watch?v=g1oFlq7D_nQ

추천
0

댓글 0개

전체 121 |RSS
파이썬 내용 검색

회원로그인

진행중 포인트경매

  1. 참여2 회 시작24.04.25 20:23 종료24.05.02 20:23
  2. 참여91 회 시작24.04.19 15:40 종료24.04.26 15:40
(주)에스아이알소프트 / 대표:홍석명 / (06211) 서울특별시 강남구 역삼동 707-34 한신인터밸리24 서관 1404호 / E-Mail: admin@sir.kr
사업자등록번호: 217-81-36347 / 통신판매업신고번호:2014-서울강남-02098호 / 개인정보보호책임자:김민섭(minsup@sir.kr)
© SIRSOFT