sql >> Database >  >> RDS >> Mysql

Overschakelen van SQLite naar MySQL met Flask SQLAlchemy

De door u genoemde zelfstudie toont de juiste manier om verbinding te maken met MySQL met behulp van SQLAlchemy. Hieronder vindt u uw code met zeer kleine wijzigingen:

Mijn aannames zijn dat uw MySQL-server op dezelfde machine draait als waarop Flask draait en dat de databasenaam db_name is. Als uw server niet dezelfde machine is, plaats dan het server-IP in plaats van 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()

Het is mij overkomen dat het standaardstuurprogramma dat wordt gebruikt door SQLAlchemy (mqsqldb ), wordt niet voor mij gecompileerd in mijn virtuele omgevingen. Dus ik heb gekozen voor een MySQL-stuurprogramma met volledige python-implementatie pymysql . Zodra je het hebt geïnstalleerd met behulp van pip install pymysql , zal de SQLALCHEMY_DATABASE_URI veranderen in:

app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+pymysql://username:[email protected]/db_name'

Het doel van het gebruik van ORM zoals SQLAlchemy is dat u in de meeste gevallen verschillende databases kunt gebruiken met weinig of geen verandering. Dus mijn antwoord is ja. U zou uw sqlite-code moeten kunnen gebruiken om met MySQL te werken met de URI toegewezen zoals in bovenstaande code.



  1. Problemen met privileges oplossen bij het herstellen van PostgreSQL-database

  2. PL/pgSQL controleren of een rij bestaat

  3. Oracle Datetime-functies (volledige lijst)

  4. Kan ik een HTTP GET rechtstreeks in SQL uitvoeren onder MySQL?