1. 程式人生 > >flask sqlalchemy實現增刪改查

flask sqlalchemy實現增刪改查

       近期看學習flask sqlalchemy,簡單點說flask sqlalchemy是對sqlalchemy的封裝,所以sqlalchemy支援的flask sqlalchemy也一樣。

      例如:flask連線資料庫:

app = Flask(__name__)
# mysql url配置規則 mysql://username:[email protected]/database
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://root:[email protected]:3307/test?charset=utf8'
app.config['SQLALCHEMY_COMMIT_ON_TEARDOWN'] = True

app.config['SQLALCHEMY_TRACK_MODIFICATIONS']=True
db = SQLAlchemy(app)
manager = Manager(app)

定義一個實體類:

class UserData(db.Model) :
  __tablename__ = 'tab_user'
  id = db.Column(db.String(64),primary_key=True )
  username = db.Column(db.String(30),unique=True)
  password = db.Column(db.String(20), default="")


  def __init__(self, uid, username, password):
    self.id = uid
    self.username = username
    self.password = password

然後我們對這個表進行操作

      查詢:

#查詢全部
UserData.query.all()

#執行sql的查詢

sql='select * from tab_user1 limit 0,10'
items=list()
# 執行sql ,返回值都是list(),要取值遍歷,每一個直接通過'.欄位名'的方式取指定的欄位
items=db.session.execute(sql)

#帶有條件的查詢

UserData.query.filter_by(username='name')

#多條件的查詢(查詢使用者名稱為username_0,密碼為password_0的資料)

from sqlalchemy import and_
UserData.query.filter( and_ ( UserData.username =='username_0',UserData.password=='password_0'))

#給查詢條件中加入引數類的條件如下(注意一定要有all()方法才能查詢):

name='test'
results= UserData.query.filter(UserData.username == name).all()

       插入:

db.session.add(UserData(uid,username,password))
db.session.commit()

      刪除:

#刪除name='name'的資料

UserData.query.filter_by(username='name').delete()

     修改:

#把name='name'的password更改為newdata

UserData.query.filter_by(username='name').update({'password':'newdata'})

      這樣對資料庫的增刪改查都有了。記得flask專案中有一個

 Flask(__name__,static_folder="",static_url_path=""),請把它放到__init__.py檔案中。