安裝flask-sqlalchemy
pip install flask-sqlalchemy
pip intall pymysql
初始化SQLAlchemy
from flask import Flask from flask-sqlalchemy import SQLAlchemy app=Flask(__name__) #配置sqlalchemy app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+pymysql://root:123@127.0.0.1/stu' db=SQLAlchemy(app)
定義models
#從上面的模塊導入 db
class User(db.Model):
"" 定義了三個字段, 數據庫表名為model名小寫 """
id=db.Column(db.Integer) username = db.Column(db.String(80),primary_key=True, unique=True) password = db.Column(db.String(120), unique=True) def __init__(self, id,username, email):
self.id=id self.username = username self.password = password def __repr__(self): return '<User %r>' % self.username
#執行保存數據操作 def save(self):
#session用來暫存數據庫操作的數據,最終通過commit統一提交給數據庫
db.session.add(self)
db.session.commit()
#生成表格
db.create_all()
調用models類完成對數據庫的增,刪,改,查
from models import User
#添加數據
user=User(1,'xiaoxiao','ss123')
user.save()
#按條件查詢
result=User.query.filter(User.id>5).all() result=User.query.filter(User.username=='xiaoxiao').all() #返回結果為一個列表,列表內元素為User對象,all()為返回查詢的所有結果,first()返回查詢結果中的第一個
result=User.query.filter(User.username.startswith('x')) #starstwith以什么開頭
#獲取查詢結果的總數量
count=User.query.filter(User.id>5).count()
#獲取查詢結果中指定的數據
result=User.query.filter(User.id>5).all()[1:3] #查詢結果以列表返回,所以可以根據列表的切片操作來獲取對應數據
#多條件查詢
#sqlalchemy內置了多條件查詢方法 : and_(), or()_ ,not_()
result=User.query.filter(and_(User.id>5,User.username.startswith('x'))) #查詢id大於5並且用戶名以x開頭的
result=User.query.filter(or_(User.id>5,User.username.startswith('x'))) #查詢id大於5或者用戶名以x開頭的
result=User.query.filter(and_(User.username.startswith('x'))) #查詢用戶名不是以x開頭的
#修改
result=User.query.filter(User.username=='xiaoxiao').all()[0]
result.password='000000'
db.session.commit()
#刪除
result=User.query.filter(User.username=='xiaoxiao').all()[0]
db.session.delete(result)
db.session.commit()
