gpt4 book ai didi

python - Flask、Postman 和 Mysql 多字段插入问题

转载 作者:太空宇宙 更新时间:2023-11-03 11:30:26 24 4
gpt4 key购买 nike

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

现在我们在 Postman 中插入一些数据,这些数据将使用 Flask 从前端访问并存储在 Mysql 表中。这里我们可以插入一个字段,但不能插入多个字段。这是 postman 数据: Data_Insertion_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. "键名"= '名字'2.重复输入3. 401 未授权等

有什么改进的建议吗?

最佳答案

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

关于python - Flask、Postman 和 Mysql 多字段插入问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50501409/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com