Databases 9 min read

How to Build a Flask Blog with SQLAlchemy ORM: Step‑by‑Step Guide

This article introduces SQLAlchemy as a Python ORM, shows how to install and configure it in a Flask project, defines Article and Article_Detail models, demonstrates CRUD routes, explains database migration with Flask‑Migrate, and covers comment handling and rollback procedures.

Python Crawling & Data Mining
Python Crawling & Data Mining
Python Crawling & Data Mining
How to Build a Flask Blog with SQLAlchemy ORM: Step‑by‑Step Guide

SQLAlchemy is a Python ORM library that provides an object‑relational mapping framework for database programming.

Quick‑start documentation: http://www.pythondoc.com/flask-sqlalchemy/quickstart.html

Install with: pip install sqlalchemy Configure Flask to use SQLAlchemy by adding a Config class:

class Config:
    SECRET_KEY = "abc_caonima_wocao"
    SQLALCHEMY_COMMIT_ON_TEARDOWN = True
    SQLALCHEMY_TRACK_MODIFICATIONS = True
    DEBUG = True
    SQLALCHEMY_DATABASE_URI = 'mysql+pymysql://%s:%s@%s:%s/%s' % (DB_USERNAME, DB_PASSWORD, DB_HOST, DB_PORT, DB_NAME)

Initialize the extension in the application:

app = Flask(__name__, template_folder='templates', static_folder='static')
app.config.from_object(Config)

db = SQLAlchemy(app)
db.init_app(app)

Define database models. Example Article model with fields such as id, title, author, img_url, content, tag, uuid, create_time and a relationship to Article_Detail:

class Article(db.Model):
    __tablename__ = 'article'
    id = db.Column(db.Integer, primary_key=True)
    title = db.Column(db.String(32))
    author = db.Column(db.String(32))
    img_url = db.Column(db.Text, nullable=False)
    content = db.Column(db.Text, nullable=False)
    tag = db.Column(db.String(64), nullable=True)
    uuid = db.Column(db.Text, nullable=False)
    create_time = db.Column(db.DateTime, nullable=True, default=datetime.now)
    uid = db.relationship('Article_Detail', backref='article')
    def __repr__(self):
        return '<Article %r>' % self.title

The corresponding Article_Detail model stores the article body and links back to Article via a foreign key:

class Article_Detail(db.Model):
    __tablename__ = 'article_detail'
    id = db.Column(db.Integer, primary_key=True)
    d_content = db.Column(db.Text, nullable=False)
    uid = db.Column(db.Integer, db.ForeignKey('article.id'))
    def __repr__(self):
        return '<Article_Detail %r>' % self.title

Typical CRUD routes:

@home.route('/')
def index():
    init_list = Article.query.order_by(db.desc(Article.create_time)).all()
    return render_template('home/index.html', datas=init_list)

@home.route('/article/<uuid>')
def query_detail(uuid):
    article_res = Article.query.filter_by(uuid=uuid).first()
    article_detail_res = Article_Detail.query.filter_by(uid=article_res.id).first()
    return render_template('article/{}.html'.format(uuid), a_data=article_res, d_data=article_detail_res)

Database migration is handled with flask_migrate. A minimal manager script:

# coding:utf8
from datetime import datetime
from flask_migrate import Migrate, MigrateCommand
from app import app
from app.models import db
from flask_script import Manager, Server

manage = Manager(app)
Migrate(app, db)
manage.add_command('db', MigrateCommand)

if __name__ == "__main__":
    manage.run()

Typical migration commands:

python manage.py db init

python manage.py db migrate

python manage.py db upgrade

Adding comments to an article uses a Flask route that validates a submitted form and inserts a Comment record:

@home.route('/postComment/<uuid>', methods=['GET', 'POST'])
def postComment(uuid):
    form = CommentForm()
    if request.method == "POST" and form.validate_on_submit():
        try:
            add_comment = Comment(theme=form.theme.data, email=form.email.data,
                                 content=form.content.data, uuid=uuid)
            db.session.add(add_comment)
            db.session.commit()
            return "评论成功"
        except Exception as e:
            db.session.rollback()
            return "评论失败"
    else:
        return redirect('/article/{}'.format(uuid))

Database rollback is essential for recovering from errors; Flask‑Migrate provides commands to revert migrations when needed.

Original Source

Signed-in readers can open the original source through BestHub's protected redirect.

Sign in to view source
Republication Notice

This article has been distilled and summarized from source material, then republished for learning and reference. If you believe it infringes your rights, please contactadmin@besthub.devand we will review it promptly.

migrationPythondatabaseORMFlaskSQLAlchemy
Python Crawling & Data Mining
Written by

Python Crawling & Data Mining

Life's short, I code in Python. This channel shares Python web crawling, data mining, analysis, processing, visualization, automated testing, DevOps, big data, AI, cloud computing, machine learning tools, resources, news, technical articles, tutorial videos and learning materials. Join us!

0 followers
Reader feedback

How this landed with the community

Sign in to like

Rate this article

Was this worth your time?

Sign in to rate
Discussion

0 Comments

Thoughtful readers leave field notes, pushback, and hard-won operational detail here.