0

我正在使用 Flask 在 Python 3 上开发 API 并尝试将数据插入 Mysql,但响应中只有值,我无法在 Json 对 app 的回答中正确显示。Python代码

app = Flask(__name__)
app.config['MYSQL_HOST'] = 'localhost'
app.config['MYSQL_USER'] = 'root'
app.config['MYSQL_PASSWORD'] = ''
app.config['MYSQL_DB'] = 'didaxis'
mysql = MySQL(app)

@app.route('/insertAlumno', methods = ['POST'])
def insertAlumno():
    nombre = request.json['nombre']
    apellidoPaterno = request.json['apellidoPaterno']
    apellidoMaterno = request.json['apellidoMaterno']
    fechaNacimiento = request.json['fechaNacimiento']
    direccion = request.json['direccion']
    telefono = request.json['telefono']
    correo = request.json['correo']
    matricula = request.json['matricula']
    curso = request.json['curso']

    dataUser = (nombre, apellidoPaterno, apellidoMaterno, fechaNacimiento, direccion, telefono, correo, matricula, curso)

    conect = mysql.connection.cursor()
    conect.callproc('insertarAlumno', dataUser)
    data = conect.fetchall()
    data=jsonify(data)

    return data

存储过程

DELIMITER //
CREATE PROCEDURE insertarAlumno(_nombre VARCHAR(50),
                                _apellidoPaterno VARCHAR(30),
                                _apellidoMaterno VARCHAR(30),
                                _fechaNacimiento DATE,
                                _direccion VARCHAR(100),
                                _telefono VARCHAR(20),
                                _correo VARCHAR(50),
                                _matricula VARCHAR(50),
                                _curso VARCHAR(10))
BEGIN
    DECLARE idPersonaTemp,idUserTemp INT DEFAULT 0;
    
    INSERT INTO persona (nombre,apellidoPaterno,apellidoMaterno,fechaNacimiento,direccion,telefono,correo) 
    VALUES (_nombre,_apellidoPaterno,_apellidoMaterno,_fechaNacimiento,_direccion,_telefono,_correo);
    
    SET idPersonaTemp = last_insert_id();
    
    INSERT INTO usuario (usuario,pass,estatus) 
    VALUES (_matricula,_matricula,1);
    
    SET idUserTemp = last_insert_id();
    
    INSERT INTO alumno VALUES (_matricula,idPersonaTemp,idUserTemp,_curso,1);
    
    SELECT * FROM vista_alumnos WHERE id = _matricula;

END //

我从邮递员那里得到的回复

[
    [
        "Simon",
        "Lopez",
        "Lopez",
        "Fri, 23 Oct 1998 00:00:00 GMT",
        "Miguel Hidalgo 515",
        "4761138167",
        "simon.valt23@gmail.com",
        "178724",
        "178724",
        "178724",
        9,
        9,
        "1APre",
        1
    ]
]

我希望有人可以向我解释这个问题以及如何获得一个带有列名的响应 json 来识别值。

4

1 回答 1

0

我得到了答案,在 Python 代码上添加了几行

    conect = mysql.connection.cursor()
    conect.callproc('insertarAlumno', dataUser)
    *columns=[x[0] for x in conect.description]
    data = conect.fetchall()
    *json_data=[]
    *for result in data:
        *json_data.append(dict(zip(columns,result)))
   
    *return jsonify(json_data)

以 * 开头的行与帖子相比已修改或刚刚添加。

于 2020-10-15T05:50:08.663 回答