Python Flask 数据库(flask 数据库操作)
文章标签:
bootstrap from
这篇文章讲python操作数据库,数据库里持久化保存了核心数据,Web应用可以发起查询,取回所需的数据。web应用最常使用基于关系模型的数据库,这种数据库称为SQL数据库,因为它们使用结构化查询语言(SQL)。另一种流行的数据库叫NoSQL数据库,包括文档数据库和键值对数据库,比如redis,sqlite~
ailx10
网络安全优秀回答者
网络安全硕士
去咨询
今天做的demo如下,比较简单:输入名字,
- 如果以前输入过,显示「老朋友,又见面了」
- 如果以前没有输入过,显示「买瓶水,交个朋友」
- 每次输入的名字,都会被记录到sqlite数据库中去~
如何只花1元搭建个人博客网站
作者 ailx10
去查看
1、flask-sqlalchemy管理数据库
废话不多说,先安装flask-sqlalchemy
2、定义模型
- 模型model:表示应用使用的持久化实体
- 模型一般是一个python类,类中的属性对应数据库表中的列
这块内容,书上写的非常不好,只能从网上找例子,我运气还不错,找了一个比较好的例子[1],然后成功的把书上的例子消化了~
db.Column类构造函数,这个要单独写一个类,然后import 进来这个db,否则会出问题
from flask_sqlalchemy import SQLAlchemy
db = SQLAlchemy()
- 参数1:属性字段的类型
- 剩下参数:指定属性的配置选项
from db import db
class User(db.Model):
__tablename__ = "user"
id = db.Column(db.Integer,primary_key=True,autoincrement=True)
username = db.Column(db.String(64),unique=True,index=True)
def __init__(self,username):
self.username = username
def __repr__(self):
return "<user %r>"%self.username
先初始化配置一下咱们的sqlite数据库,这是一个NoSQL数据库,我们用它来存储用户名
from db import db
import os
from flask import Flask,render_template,session,redirect,url_for
from flask_bootstrap import Bootstrap
from flask_moment import Moment
app = Flask(__name__)
basedir = os.path.abspath(os.path.dirname(__file__))
app.config["SQLALCHEMY_DATABASE_URI"]="sqlite:///"+os.path.join(basedir,"data.sqlite")
app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = False
app.config["SECRET_KEY"]="ailx10@zhihu/2021/2022"
bootstrap = Bootstrap(app)
moment = Moment(app)
with app.app_context():
db.init_app(app)
db.create_all()
3、数据库操作
这块就是增删改查没啥好说的,用到的时候查一下就可以了
- 增/改
db.session.add()
db.session.commit()
- 删
db.session.delete()
db.session.commit()
- 查
User.query.all()
User.query.filter_by().all()
User.query.filter_by().first()
4、在视图函数中操作数据库
- 新朋友(输入一个新的用户名)
- 老朋友(输入一个老的用户名)
from models import User
from db import db
from init import app
from flask import Flask,render_template,session,redirect,url_for
from form import NameForm
@app.route("/",methods=["GET","POST"])
def index():
form = NameForm()
if form.validate_on_submit():
user = User.query.filter_by(username=form.name.data).first()
if user is None:
user = User(username=form.name.data)
db.session.add(user)
db.session.commit()
session["known"] = False
else:
session["known"] = True
form.name.data = ""
return redirect(url_for("index"))
return render_template("index.html",
form=form,
name=session.get("name"),
known=session.get("known",False))
if __name__ == "__main__":
app.run(host="192.168.0.105",port=80,debug=True)
本篇完,谢谢大家~