flask 框架操作MySQL數(shù)據(jù)庫(kù)簡(jiǎn)單示例
本文實(shí)例講述了flask 框架操作MySQL數(shù)據(jù)庫(kù)。分享給大家供大家參考,具體如下:
一、創(chuàng)建數(shù)據(jù)庫(kù)表格
""" Created on 19-10-8 @requirement:Anaconda 4.3.0 (64-bit) Python3.6 @description:創(chuàng)建表格 """ import pymysql server = '127.0.0.1' user = 'root' password = 'password' # 連接數(shù)據(jù)庫(kù) conn = pymysql.connect(server, user, password, database='information_collection') # 獲取連接 cursor = conn.cursor() # 獲取游標(biāo) # "**ENGINE=InnoDB DEFAULT CHARSET=utf8**"-創(chuàng)建表的過(guò)程中增加這條,中文就不是亂碼 # 創(chuàng)建表 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 """) # 查詢數(shù)據(jù)庫(kù)表user內(nèi)容 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) # # 插入數(shù)據(jù),注:與sqlserver有些區(qū)別 cursor.execute("INSERT INTO user VALUES('%s','%s','%s','%s')" % ('xiaoming','qwe','ming','@163.com')) # 提交數(shù)據(jù),才會(huì)寫入表格 conn.commit() # 關(guān)閉游標(biāo)關(guān)閉數(shù)據(jù)庫(kù) 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 首選需要初始化實(shí)例,并讀取配置文件: my_config = configparser.ConfigParser() my_config.read('db.conf') # 連接數(shù)據(jù)庫(kù)information_collection app.config['SQLALCHEMY_DATABASE_URI'] = os.environ.get('DEV_DATABASE_URL') or \ "mysql+pymysql://root:password@127.0.0.1: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 # 獲取用戶列表,所有數(shù)據(jù) @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) # 添加用戶數(shù)據(jù),一條一條添加 @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_name': user.user_name, 'user_nickname': user.user_nickname, 'user_email': user.user_email} return jsonify(data=result) # 獲取單條數(shù)據(jù) @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': '找不到數(shù)據(jù)'} else: result = {'user_id': user.user_id, 'user_name': user.user_name, 'user_nickname': user.user_nickname, 'user_email': user.user_email} return jsonify(data=result) # 修改用戶數(shù)據(jù) @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_name': user.user_name, 'user_password': user.user_password, 'user_nickname': user.user_nickname, 'user_email': user.user_email} return jsonify(data=result) # 刪除用戶數(shù)據(jù) @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()
三、返回?cái)?shù)據(jù)的樣式
{
"data": {
"user_email": "@126.com",
"user_id": 6,
"user_name": "xiaoli",
"user_nickname": "lili"
}
}
希望本文所述對(duì)大家基于flask框架的Python程序設(shè)計(jì)有所幫助。
相關(guān)文章
pandas實(shí)現(xiàn)導(dǎo)出數(shù)據(jù)的四種方式
這篇文章主要介紹了pandas實(shí)現(xiàn)導(dǎo)出數(shù)據(jù)的四種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12PyTorch中torch.tensor與torch.Tensor的區(qū)別詳解
這篇文章主要介紹了PyTorch中torch.tensor與torch.Tensor的區(qū)別詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05Python如何自動(dòng)獲取目標(biāo)網(wǎng)站最新通知
這篇文章主要介紹了Python如何自動(dòng)獲取目標(biāo)網(wǎng)站最新通知,本文給大家分享實(shí)現(xiàn)思路及示例代碼,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06python3中celery異步框架簡(jiǎn)單使用+守護(hù)進(jìn)程方式啟動(dòng)
這篇文章主要介紹了python3中celery異步框架簡(jiǎn)單使用+守護(hù)進(jìn)程方式啟動(dòng),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01利用python實(shí)現(xiàn)全屏愛(ài)心雨向喜歡的人表白
馬上520了,教大家用Python做一個(gè)下愛(ài)心雨的特效,這篇文章主要給大家介紹了關(guān)于利用python實(shí)現(xiàn)全屏愛(ài)心雨向喜歡的人表白的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05python數(shù)學(xué)建模之Matplotlib?實(shí)現(xiàn)圖片繪制
這篇文章主要介紹了python數(shù)學(xué)建模之Matplotlib?實(shí)現(xiàn)圖片繪制,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-07-07python實(shí)現(xiàn)輸入數(shù)字的連續(xù)加減方法
今天小編就為大家分享一篇python實(shí)現(xiàn)輸入數(shù)字的連續(xù)加減方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-06-06python爬取w3shcool的JQuery課程并且保存到本地
本文主要介紹python爬取w3shcool的JQuery的課程并且保存到本地的方法解析。具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧2017-04-04