sql >> Databáze >  >> RDS >> Mysql

TypeError:kurzor() získal neočekávaný argument klíčového slova 'dictionary' pomocí flaskext.mysql

Můžete sledovat tuto odpověď:https://stackoverflow.com/a/41388992/3129414

Úprava stávajícího kódu:

  • použijte DictCursor v MySQL inicializace
  • odebrat dictionary=True od kurzoru
  • použijte json balíček pro převod položek slovníku do formátu json

app.py :

import json
from flask import Flask
from flaskext.mysql import MySQL
from pymysql.cursors import DictCursor

app = Flask(__name__)
app.config['MYSQL_DATABASE_USER'] = 'root'
app.config['MYSQL_DATABASE_PASSWORD'] = '123'
app.config['MYSQL_DATABASE_DB'] = 'practice_db'
app.config['MYSQL_DATABASE_HOST'] = 'localhost'
mysql = MySQL(cursorclass=DictCursor)
mysql.init_app(app)
conn = mysql.connect()

@app.route("/", methods=['GET'])
def home():
    email_address = '[email protected]'
    cursor = conn.cursor();
    cursor.execute(
            'SELECT * FROM user_table WHERE email = (%s)', (email_address,)
        )
    users = cursor.fetchall()
    return json.dumps(users)

app.run(debug=True)

Snímek obrazovky:




  1. Jak vyřešit problém s kódováním znaků MySQL?

  2. Spokojenost vede k:Riziko se stává realitou

  3. Jak zahrnout soubory jar do uložené procedury Java v Oracle?

  4. Jak číst poslední řádek s SQL Server