【发布时间】: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字段中插入字符串数据时。