flask、postman和mysql多字段插入问题

dwbf0jvd  于 2021-06-21  发布在  Mysql
关注(0)|答案(1)|浏览(252)

我们正在尝试使用flask postman mysql为应用程序构建一个原型。
现在我们正在postman中插入一些数据,这些数据将使用flask从前端访问并存储在mysql表中。这里我们可以插入一个字段,但不能插入多个字段。以下是 Postman 数据:

下面是用于插入单个记录的 flask 中的代码:

from flask import Flask, request, jsonify, make_response
from flask_sqlalchemy import SQLAlchemy
import jwt
import datetime
from functools import wraps
import mysql.connector

app = Flask(__name__)

app.config['SECRET_KEY'] = 'thisissecret'
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+pymysql://root:1234@localhost/flask2018'
db = SQLAlchemy(app)

class Users(db.Model):
    name = db.Column(db.Integer, primary_key=True)
    password = db.Column(db.String(80))
@app.route('/users', methods=['POST'])

def create_user():

    data = request.get_json()

    create_user= Users( name=data['name'], password=data['password'])

    db.session.add(create_user)
    db.session.commit()

    return jsonify({'message' : 'New user created!'})

if _name_ == '__main__':
    app.run(debug=True,port=4022)

下面是flask中用于多个记录的代码:(给出错误)

from flask import Flask, jsonify,request
from flaskext.mysql import MySQL

app = Flask(__name__)
mysql = MySQL(app)

# MySQL configurations

app.config['MYSQL_DATABASE_USER'] = 'root'
app.config['MYSQL_DATABASE_PASSWORD'] = '1234'
app.config['MYSQL_DATABASE_DB'] = 'flask2018'
app.config['MYSQL_DATABASE_HOST'] = 'localhost'

mysql.init_app(app)

@app.route('/users', methods=['POST'])
def get():
    cur = mysql.connect().cursor()
    json_dict = request.get_json()

    name = str(json_dict["name"])
    password = str(json_dict["password"])
    #with cur.cursor() as cursor:
    values = 'INSERT INTO users(name,password) VALUES(%s,%s)'
    cur.execute(values, (name,password))
    mysql.connect().commit()

    #cur.close()

    return jsonify()

if _name_ == '__main__':
    app.run(debug=True,port=4022)

当我们运行上述程序时,有时会显示错误,如1。”key name“='名称'2。重复条目3。401未授权等
有什么改进的建议吗?

7vux5j2d

7vux5j2d1#

我发现你的实现有几个问题。您的请求主体有一个字段 users 以及 names 是在 users 数组。这就是为什么会出现密钥错误,因为您正在尝试访问 name 即使它在田野里 users 范围。另一个问题是数据库模式中名称字段的定义。您将其定义为整数,但传入的是字符串值。
要获取姓名和密码,您可以

json_dict = request.get_json()
for user in json_dict["users"]:
    name = str(json_dict["name"])
    password = str(json_dict["password"])

我想您会得到重复的输入字段,因为您多次尝试发布相同的数据。因为你的主键是 name (我不建议),你必须确保 name 不会重复,因为无法插入具有相同值的多个主键。

相关问题