pip install flask-sqlalchemy
pip intall pymysql
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)
#從上面的模塊導入 dbmysql
class User(db.Model): sql
"" 定義了三個字段, 數據庫表名爲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()
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()