Mysql
 sql >> Base de Dados >  >> RDS >> Mysql

Mudando de SQLite para MySQL com Flask SQLAlchemy


O tutorial indicado por você mostra a maneira correta de se conectar ao MySQL usando SQLAlchemy. Abaixo está o seu código com poucas alterações:

Minhas suposições são que seu servidor MySQL está sendo executado na mesma máquina em que o Flask está sendo executado e o nome do banco de dados é db_name. Caso seu servidor não seja a mesma máquina, coloque o IP do servidor no lugar de localhost .
from flask import Flask
from flask.ext.sqlalchemy import SQLAlchemy

app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://username:[email protected]/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', '[email protected]')

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()

Aconteceu comigo que o driver padrão usado pelo SQLAlchemy (mqsqldb ), não é compilado para mim em meus ambientes virtuais. Então, optei por um driver MySQL com implementação completa de python pymysql . Depois de instalá-lo usando pip install pymysql , o SQLALCHEMY_DATABASE_URI mudará para:
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+pymysql://username:[email protected]/db_name'

O objetivo de usar ORM como SQLAlchemy é que você pode usar banco de dados diferente com pouca ou nenhuma alteração na maioria dos casos. Então, minha resposta é sim. Você deve ser capaz de usar seu código sqlite para trabalhar com o MySQL com o URI mapeado como no código acima.