Python 无法使数据库在使用flask的本地主机上工作

Python 无法使数据库在使用flask的本地主机上工作,python,mysql,flask,Python,Mysql,Flask,我现在使用的是最基本的代码,但仍然不起作用: from flask import Flask, render_template from flaskext.mysql import MySQL mysql = MySQL() app = Flask(__name__) # MySQL configurations app.config['MYSQL_DATABASE_USER'] = 'root' app.config['MYSQL_DATABASE_PASSWORD'] = '' app.

我现在使用的是最基本的代码,但仍然不起作用:

from flask import Flask, render_template
from flaskext.mysql import MySQL

mysql = MySQL()
app = Flask(__name__)

# MySQL configurations
app.config['MYSQL_DATABASE_USER'] = 'root'
app.config['MYSQL_DATABASE_PASSWORD'] = ''
app.config['MYSQL_DATABASE_DB'] = 'people'
app.config['MYSQL_DATABASE_HOST'] = 'localhost'
mysql.init_app(app)

@app.route('/test')
def test():
    conn = mysql.connect()
    cursor = conn.cursor()
    sql = "SELECT * from tbl_user"
    cursor.execute(sql)
    results = cursor.fetchall()
    cursor.close()
    conn.close()
    return results

if __name__ == "__main__":
    app.run(debug=True)
我曾尝试通过Mysql cli在localhost上连接到我的db,效果很好。我使用mysql-u root进入,它接受它,然后我使用人,它工作正常,然后我可以执行select语句

以下是我得到的错误:

Traceback (most recent call last):
  File "C:\Python27\lib\site-packages\flask\app.py", line 1836, in __call__
    return self.wsgi_app(environ, start_response)
  File "C:\Python27\lib\site-packages\flask\app.py", line 1820, in wsgi_app
    response = self.make_response(self.handle_exception(e))
  File "C:\Python27\lib\site-packages\flask\app.py", line 1403, in handle_exception
    reraise(exc_type, exc_value, tb)
  File "C:\Python27\lib\site-packages\flask\app.py", line 1817, in wsgi_app
    response = self.full_dispatch_request()
  File "C:\Python27\lib\site-packages\flask\app.py", line 1478, in full_dispatch_request
    response = self.make_response(rv)
  File "C:\Python27\lib\site-packages\flask\app.py", line 1577, in make_response
    rv = self.response_class.force_type(rv, request.environ)
  File "C:\Python27\lib\site-packages\werkzeug\wrappers.py", line 847, in force_type
    response = BaseResponse(*_run_wsgi_app(response, environ))
  File "C:\Python27\lib\site-packages\werkzeug\wrappers.py", line 57, in _run_wsgi_app
    return _run_wsgi_app(*args)
  File "C:\Python27\lib\site-packages\werkzeug\test.py", line 871, in run_wsgi_app
    app_rv = app(environ, start_response)
TypeError: 'tuple' object is not callable

但正如您所看到的,只要我使用Flask,就会出现这个错误。

这个问题与flaskext.mysql和db连接无关。在@app.route'/test'语句中,返回一个元组,它是从数据库中选择的结果。
在Flask中,您应该返回一些内容。

问题与flaskext.mysql和db连接无关。在@app.route'/test'语句中,返回一个元组,它是从数据库中选择的结果。
在Flask中,您应该返回一些内容。

您的视图应该返回字符串格式的模板或HTML代码。我猜您正在尝试显示数据库查询的结果,因此一种正确的方法是使用render_template函数通过模板传递数据。
看看这里:

您的视图应该返回字符串格式的模板或HTML代码。我猜您正在尝试显示数据库查询的结果,因此一种正确的方法是使用render_template函数通过模板传递数据。 请看这里: