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  

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



 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM