1. 程式人生 > 資料庫 >flask 框架操作MySQL資料庫簡單示例

flask 框架操作MySQL資料庫簡單示例

本文例項講述了flask 框架操作MySQL資料庫。分享給大家供大家參考,具體如下:

一、建立資料庫表格

"""
Created on 19-10-8
@requirement:Anaconda 4.3.0 (64-bit) Python3.6
@description:建立表格
"""
import pymysql
server = '127.0.0.1'
user = 'root'
password = 'password'
# 連線資料庫
conn = pymysql.connect(server,user,password,database='information_collection') # 獲取連線
cursor = conn.cursor() # 獲取遊標
# "**ENGINE=InnoDB DEFAULT CHARSET=utf8**"-建立表的過程中增加這條,中文就不是亂碼
# 建立表
cursor.execute("""
CREATE TABLE if not exists user(
   user_id INT NOT NULL auto_increment primary key,user_name VARCHAR(100),user_password VARCHAR(100),user_nickname VARCHAR(100),user_email VARCHAR(100)
   )
   ENGINE=InnoDB DEFAULT CHARSET=utf8
 """)
# 查詢資料庫表user內容
cursor.execute('SELECT * FROM user')
# 檢視一行 多行:cursor.fetchall()
row = cursor.fetchone()
print(row)
# if row[0] is None:
#   row0 = list(row)
#   row0[0] = 0
#   row = tuple(row0)
# # 插入資料,注:與sqlserver有些區別
cursor.execute("INSERT INTO user VALUES('%s','%s','%s')" % ('xiaoming','qwe','ming','@163.com'))
# 提交資料,才會寫入表格
conn.commit()
# 關閉遊標關閉資料庫
cursor.close()
conn.close()

二、flask操作mysql

"""
Created on 19-10-8
@requirement:Anaconda 4.3.0 (64-bit) Python3.6
@description:
"""
from flask_sqlalchemy import SQLAlchemy
from flask import Flask,jsonify,request
import configparser
import os
app = Flask(__name__)
# 使用ConfigParser 首選需要初始化例項,並讀取配置檔案:
my_config = configparser.ConfigParser()
my_config.read('db.conf')
# 連線資料庫information_collection
app.config['SQLALCHEMY_DATABASE_URI'] = os.environ.get('DEV_DATABASE_URL') or \
               "mysql+pymysql://root:[email protected]:3306/information_collection"
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = True
mydb = SQLAlchemy()
mydb.init_app(app)
# 使用者模型
class User(mydb.Model):
  user_id = mydb.Column(mydb.Integer,primary_key=True)
  user_name = mydb.Column(mydb.String(60),nullable=False)
  user_password = mydb.Column(mydb.String(30),nullable=False)
  user_nickname = mydb.Column(mydb.String(50))
  user_email = mydb.Column(mydb.String(30),nullable=False)
  def __repr__(self):
    return '<User %r>' % self.user_name
# 獲取使用者列表,所有資料
@app.route('/users',methods=['GET'])
def getUsers():
  data = User.query.all()
  datas = []
  for user in data:
    datas.append({'user_id': user.user_id,'user_name': user.user_name,'user_nickname': user.user_nickname,'user_email': user.user_email})
  return jsonify(data=datas)
# 新增使用者資料,一條一條新增
@app.route('/user',methods=['POST'])
def addUser():
  user_name = request.form.get('user_name')
  user_password = request.form.get('user_password')
  user_nickname = request.form.get('user_nickname')
  user_email = request.form.get('user_email')
  user = User(user_name=user_name,user_password=user_password,user_nickname=user_nickname,user_email=user_email)
  try:
    mydb.session.add(user)
    mydb.session.commit()
  except:
    mydb.session.rollback()
    mydb.session.flush()
  userId = user.user_id
  if (user.user_id is None):
    result = {'msg': '新增失敗'}
    return jsonify(data=result)
  data = User.query.filter_by(user_id=userId).first()
  result = {'user_id': user.user_id,'user_email': user.user_email}
  return jsonify(data=result)
# 獲取單條資料
@app.route('/user/<int:userId>',methods=['GET'])
def getUser(userId):
  user = User.query.filter_by(user_id=userId).first()
  if (user is None):
    result = {'msg': '找不到資料'}
  else:
    result = {'user_id': user.user_id,'user_email': user.user_email}
  return jsonify(data=result)
# 修改使用者資料
@app.route('/user/<int:userId>',methods=['PATCH'])
def updateUser(userId):
  user_name = request.form.get('user_name')
  user_password = request.form.get('user_password')
  user_nickname = request.form.get('user_nickname')
  user_email = request.form.get('user_email')
  try:
    user = User.query.filter_by(user_id=userId).first()
    if (user is None):
      result = {'msg': '找不到要修改的記錄'}
      return jsonify(data=result)
    else:
      user.user_name = user_name
      user.user_password = user_password
      user.user_nickname = user_nickname
      user.user_email = user_email
      mydb.session.commit()
  except:
    mydb.session.rollback() # 回滾
    mydb.session.flush() # 重置
  userId = user.user_id
  data = User.query.filter_by(user_id=userId).first()
  result = {'user_id': user.user_id,'user_password': user.user_password,'user_email': user.user_email}
  return jsonify(data=result)
# 刪除使用者資料
@app.route('/user/<int:userId>',methods=['DELETE'])
def deleteUser(userId):
  User.query.filter_by(user_id=userId).delete()
  mydb.session.commit()
  return getUsers()
if __name__ == '__main__':
  app.run()

三、返回資料的樣式

{
"data": {
"user_email": "@126.com",
"user_id": 6,
"user_name": "xiaoli",
"user_nickname": "lili"
}
}

希望本文所述對大家基於flask框架的Python程式設計有所幫助。