【问题标题】:Flask,Postman and Mysql multiple fields insertion issueFlask、Postman 和 Mysql 多字段插入问题
【发布时间】:2018-05-24 05:09:42
【问题描述】:

我们正在尝试使用 Flask-Postman-Mysql 为应用程序构建原型。

现在我们正在 Postman 中插入一些数据,这些数据将使用 Flask 从前端访问并存储在 Mysql 表中。在这里,我们可以插入一个字段,但不能插入多个字段。 这是邮递员的数据:

这是 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.“键名”='名称' 2.重复条目 3. 401未授权等

有什么改进建议吗?

【问题讨论】:

  • 您将name 指定为主键字段。 name = db.Column(db.Integer, primary_key=True)。这背后有什么原因吗。
  • 无特殊原因,我们只是想将任何一个字段作为主键来传递数据。
  • 所以,这将是name 字段的问题。请创建其他字段,例如 id 作为主键,name 作为 CharField。因为当您在 name 字段中插入字符串数据时。

标签: python mysql flask


【解决方案1】:

我发现您的实施存在一些问题。 您的请求正文有一个字段 usersnamesusers 数组中。这就是您遇到关键错误的原因,因为您尝试访问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 不重复,因为您不能插入具有相同值的多个主键。

【讨论】:

  • 我实施了您的建议。 Id 字段现在是主键,但在执行时会引发错误 - Key error:"id" 。 (我们主要关注第二个项目......)
  • @RRSS 你能给我们更多细节吗?你是如何将 id 插入数据库的?你用的是什么数据类型?
  • 我在 Mysql 中创建了一个表,其中包含字段 ID(int,主键)(n 它是自动递增的),名称(varchar),密码(varchar)。我已经从 POSTMAN 提供了输入数据,如 abv 图像所示。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2015-08-02
  • 2022-11-13
  • 2011-01-11
  • 2011-08-05
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多