一聚教程网:一个值得你收藏的教程网站

最新下载

热门教程

python中SQLAlchemy使用前端页面实现插入数据代码示例

时间:2022-06-25 01:19:30 编辑:袖梨 来源:一聚教程网

本篇文章小编给大家分享一下python中SQLAlchemy使用前端页面实现插入数据代码示例,文章代码介绍的很详细,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。

1.实验效果

如果插入的数据已经存在于数据库中,则出现以下提示:

查看数据库表中的数据,发现已经将数据存入了数据库表中:

2.主main.py文件

import os
from flask_sqlalchemy import SQLAlchemy
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import String,Integer,create_engine,Column
from flask import Flask,render_template,redirect,request,url_for,abort,jsonify

app=Flask(__name__)

class Config:
    """相关配置"""
    # cmd:
    # 创建数据库:create database flaskdb(数据库名) default charset(类型) utf8;
    # 使用数据:use flaskdb
    # 查看数据库表:show tables;
    SQLALCHEMY_DATABASE_URI='mysql+pymysql://root:[email protected]:3306/flaskdb'
    SQLALCHEMY_TRACK_MODIFICATIONS=True

app.config.from_object(Config)
#创建数据库
mysql=SQLAlchemy(app)
#创建表
class Moster(mysql.Model):
    """管理员表名"""
    __tablename__='moster'
    username=Column(String(128),primary_key=True)
    password=Column(String(128),unique=True)

@app.route('//',methods=['POST','GET'])
def Insert_User(username,password):
    #判断数据库表中是否已经存在了此用户,如果存在,则不进行插入数据
    data=Moster.query.filter(Moster.username==username).all()
    if data==[]:
        # 创建对象,进行数据的插入
        mos = Moster(username=username, password=password)
        # 创建session
        mysql.session.add(mos)
        mysql.session.commit()
        # 关闭数据库
        mysql.session.close()
        return jsonify('Add the data Successed!')
    else:
        return jsonify('The data have been existed!')


@app.route('/index',methods=['POST','GET'])
def index():
    if request.method=='POST':
        username=request.form.get('username')
        password=request.form.get('password')
        return redirect(url_for('Insert_User',username=username,password=password))
    return render_template('mysql.html')

if __name__ == '__main__':
    print('Pycharm')
    # 对数据库进行清除,让数据库是“干净的”
    # mysql.drop_all()
    # 创建表
    mysql.create_all()
    app.run(debug=True)

3.前端mysql.html文件




    
    MySQL
    


    



热门栏目