flask-sqlalchemy 用法總結

安裝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  

 #從上面的模塊導入 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()

調用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()
相關文章
相關標籤/搜索