Maison >développement back-end >Tutoriel Python >Framework ORM puissant de Django et accès léger à la base de données de Flask

Framework ORM puissant de Django et accès léger à la base de données de Flask

PHPz
PHPzoriginal
2023-09-28 11:01:541140parcourir

Framework ORM puissant de Django et accès léger à la base de données de Flask

Le puissant ORM du framework Django et l'accès léger à la base de données Flask

Introduction :
Dans le développement Web, la base de données est un élément indispensable. L'accès et les opérations aux bases de données sont essentiels aux performances et à la fiabilité d'une application Web. Django et Flask sont deux frameworks Web Python populaires qui offrent différentes manières d'accéder aux bases de données. Cet article présentera le puissant ORM (Object Relational Mapping) dans le framework Django et la méthode légère d'accès aux bases de données dans le framework Flask, et fournira des exemples de code spécifiques.

  1. Puissant framework ORM de Django
    Django est un framework d'application Web complet, dont ORM est une partie importante. ORM est une technologie de programmation qui permet aux développeurs d'exploiter la base de données de manière orientée objet en mappant les tables de la base de données avec des objets Python. L'ORM de Django fournit des fonctions riches et une syntaxe pratique, qui peuvent effectuer des opérations complexes de requête, d'insertion, de mise à jour et de suppression sur la base de données.

Ce qui suit est un exemple simple de Django ORM qui montre comment créer une classe de modèle, insérer des données et interroger des données via ORM :

from django.db import models

class User(models.Model):
    name = models.CharField(max_length=50)
    age = models.IntegerField()

# 插入数据
user1 = User(name='Alice', age=25)
user1.save()

user2 = User(name='Bob', age=30)
user2.save()

# 查询数据
users = User.objects.all()
for user in users:
    print(user.name, user.age)

Dans le code ci-dessus, nous définissons d'abord une classe de modèle utilisateur, qui est mappée à la base de données. formulaire "utilisateur". Ensuite, nous avons créé deux objets User et les avons enregistrés dans la base de données. Enfin, grâce à la méthode User.objects.all(), nous obtenons tous les objets User de la base de données et imprimons leurs noms et âges.

L'ORM de Django fournit également un riche ensemble de méthodes de requête, telles que filter(),exclus() et annotate(), etc., qui peuvent filtrer les données en fonction de conditions, exclure les données spécifiées et effectuer des opérations d'agrégation. De plus, ORM prend également en charge des fonctions avancées telles que la gestion des transactions, la migration des données et l'association de modèles, ce qui est très adapté aux exigences complexes d'exploitation de bases de données.

  1. Accès léger à la base de données avec Flask
    Comparé à Django, Flask est un framework Web plus léger qui n'a pas d'ORM intégré. Cependant, Flask fournit le package d'extension « Flask-SQLAlchemy », qui est une version intégrée à Flask de SQLAlchemy et fournit une prise en charge ORM pour les applications Flask.

SQLAlchemy est une boîte à outils Python SQL qui permet aux développeurs d'utiliser le langage SQL pour les opérations de base de données en Python en fournissant une interface d'accès à la base de données efficace et flexible. Flask-SQLAlchemy intègre SQLAlchemy et fournit un accès pratique à la base de données.

Ce qui suit est un exemple simple Flask-SQLAlchemy qui montre comment utiliser ORM pour les opérations de base de données :

from flask import Flask
from flask_sqlalchemy import SQLAlchemy

app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///users.db'
db = SQLAlchemy(app)

class User(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(50))
    age = db.Column(db.Integer)

# 插入数据
user1 = User(name='Alice', age=25)
db.session.add(user1)
db.session.commit()

user2 = User(name='Bob', age=30)
db.session.add(user2)
db.session.commit()

# 查询数据
users = User.query.all()
for user in users:
    print(user.name, user.age)

Dans le code ci-dessus, nous créons d'abord une application Flask et configurons la connexion à la base de données. Ensuite, une classe de modèle utilisateur est définie et les types de table et de champ sont spécifiés en étendant la syntaxe de Flask-SQLAlchemy. Ensuite, nous avons créé deux objets utilisateur, obtenu tous les objets utilisateur dans la base de données via db.session.add()db.session.commit()方法将它们加入数据库中,最后通过User.query.all() et imprimé leurs noms et âges.

En plus des opérations de base de base de données, Flask-SQLAlchemy prend également en charge les requêtes complexes, la gestion des transactions, la migration de données, l'association de modèles et d'autres fonctions, qui peuvent répondre aux besoins de bases de données les plus courants.

Résumé : 
Le framework Django fournit de riches fonctions d'accès aux bases de données grâce à son puissant ORM, adapté aux opérations de bases de données complexes et aux projets à grande échelle. Le framework Flask fournit une méthode légère d'accès à la base de données via Flask-SQLAlchemy, qui convient aux petits projets ou aux scénarios avec de faibles exigences d'accès à la base de données. En fonction des besoins réels, nous pouvons choisir le framework et la méthode d'accès à la base de données appropriés, et utiliser les fonctions et la syntaxe qu'ils fournissent pour développer des applications Web efficaces et fiables.

Référence :

  1. Documentation Django [En ligne]. Disponible : https://docs.djangoproject.com/
  2. Documentation Flask [En ligne]. documentation. [En ligne] Disponible : https://www.sqlalchemy.org/
  3. Documentation Flask-SQLAlchemy [En ligne]

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn