我正在构建一个带有AngularJS前端的基本Flask应用程序,目前我需要连接到我用Godaddy phpmyadmin托管的MySQL数据库。
这是我__init__.py
from flask import Flask
from flask.ext.sqlalchemy import SQLAlchemy
# Create instnace called app
app = Flask(__name__)
app.config['SQLAlchemy_DATABASE_URI'] = 'mysql://username:password#@xxxxxx.hostedresource.com/dbname'
# Create SQLAlchemy object
db = SQLAlchemy(app)
# ...
这是我的models.py
from app import app, db
class UsersPy(db.Model):
__tablename__ = "userspy"
id = db.Column(db.Integer, primary_key=True)
username = db.Column(db.String, nullable=False)
password = db.Column(db.String, nullable=False)
def __init__(self, username, password):
self.username = username
self.password = password
def __repr__(self):
return '<title {}'.format(self.username)
这是我的views.py:
的摘录from app import app, db
from app.models import UsersPy
from flask import render_template, request, redirect, url_for, jsonify, session, flash
@app.route('/testdb/')
def testdb():
admin = UsersPy('user1', 'password1')
guest = UsersPy('user2', 'password2')
db.session.add(admin)
db.session.add(guest)
#db.session.merge(admin)
#db.session.merge(guest)
db.session.commit()
results = UsersPy.query.all()
json_results = []
for result in results:
d = {'username': result.username,
'password': result.password}
json_results.append(d)
return jsonify(items=json_results)
所有这些都运行良好,当您访问/ testdb / location时,用户被“创建”并以JSON格式显示,但是Godaddy托管的实际数据库没有更新,因此不能进行真正的连接或者由于某种原因失败了。我已经创建了userspy数据库表,但add()和commit()函数实际上并没有将用户添加到数据库中。我无法弄清楚如何巩固SQLAlchemy和MySQL数据库之间的连接。感谢任何帮助。谢谢。
答案 0 :(得分:2)
调试此问题的第一步是在应用配置中将SQLALCHEMY_ECHO
设置为True
。这将导致打印出SQLAlchemy正在执行的实际MySQL数据库语句。
另外,值得注意的是SQLAlchemy_DATABASE_URI
与SQLALCHEMY_DATABASE_URI
不同,the Flask-SQLAlchemy documentation表示配置密钥应该是什么。