Посоченият от вас урок показва правилния начин за свързване с MySQL с помощта на SQLAlchemy. По-долу е вашият код с много малки промени:
Моите предположения са, че вашият MySQL сървър работи на същата машина, където работи Flask и името на базата данни е db_name. В случай, че вашият сървър не е същата машина, поставете IP сървъра на мястото на localhost .
from flask import Flask
from flask.ext.sqlalchemy import SQLAlchemy
app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://username:example@sqldat.com/db_name'
db = SQLAlchemy(app)
class User(db.Model):
id = db.Column(db.Integer, primary_key=True)
username = db.Column(db.String(80), unique=True)
email = db.Column(db.String(120), unique=True)
def __init__(self, username, email):
self.username = username
self.email = email
def __repr__(self):
return '<User %r>' % self.username
admin = User('admin', 'example@sqldat.com')
db.create_all() # In case user table doesn't exists already. Else remove it.
db.session.add(admin)
db.session.commit() # This is needed to write the changes to database
User.query.all()
User.query.filter_by(username='admin').first()
Случи ми се драйверът по подразбиране, използван от SQLAlchemy (mqsqldb ), не се компилира за мен в моите виртуални среди. Затова избрах MySQL драйвер с пълна реализация на python pymysql . След като го инсталирате с помощта на pip install pymysql , SQLALCHEMY_DATABASE_URI ще се промени на:
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+pymysql://username:example@sqldat.com/db_name'
Целта на използването на ORM като SQLAlchemy е, че можете да използвате различна база данни с малка или никаква промяна в повечето случаи. Така че моят отговор е да. Трябва да можете да използвате своя sqlite код, за да работите с MySQL с URI, картографиран, както в кода по-горе.