Manipuler des données en provenance de bases relationnelles sans recourir à un excès d'architecture

Magazine
Marque
GNU/Linux Magazine
HS n°
Numéro
53
Mois de parution
mars 2011
Domaines


Résumé
De la même manière que nous avons manipulé des données en provenance de CSV ou LDAP en utilisant conjointement et uniquement les listes et les dictionnaires, nous allons gérer des données en provenance de bases relationnelles en utilisant l'ORM SQLAlchemy présenté dans l'article précédent.Nous allons chercher à répondre à des cas d'utilisation concrets et à apercevoir quelques voies qui pourront permettre d'industrialiser du code efficace, simple et performant.

1. Création d'une classe générique

1.1 Code

Voici une classe conçue pour prendre en compte un certain nombre de cas d'utilisation d'une base de données. Il s'agira ici de simplement lire une table.

Le principe premier de l'utilisation d'une classe telle que celle-ci est de lui déléguer tout le travail de gestion de la connexion, de la session, du mapping et d'avoir à sa disposition diverses méthodes. Ici, une méthode permet de trouver tous les enregistrements d'une table, et un enregistrement dont on connaît l'identifiant.

# -*- coding: utf-8 -*-

from sqlalchemy import MetaData, create_engine

from sqlalchemy.orm import scoped_session, sessionmaker, mapper

from sqlalchemy.schema import Table

class SQL_Handler( object ):

 """This object is an SQL Handler. [...]"""

 def __init__( self, **datas ):

  url = self.url( **datas )

  self.metadata = MetaData( url )

  self.table = Table( datas["table"], self.metadata , autoload=True)

  self.columns = [str(column).split(".")[1] for column in...

Cet article est réservé aux abonnés. Il vous reste 95% à découvrir.
à partir de 21,65€ HT/mois/lecteur pour un accès 5 lecteurs à toute la plateforme
J'en profite


Articles qui pourraient vous intéresser...

Utilisation de l’IDE Visual Studio Code

Magazine
Marque
GNU/Linux Magazine
HS n°
Numéro
112
Mois de parution
janvier 2021
Domaines
Résumé

Visual Studio Code, un outil dont Microsoft est à l’origine, est Open Source et gratuit, multiplateforme et ouvert grâce à son architecture d’extensions. Mis à jour mensuellement, il est écrit par des développeurs pour des développeurs.

La surcharge ou overloading en Python

Magazine
Marque
GNU/Linux Magazine
HS n°
Numéro
112
Mois de parution
janvier 2021
Domaines
Résumé

On vous l’a dit et répété : Python est un langage à typage dynamique ! Ah... donc, on ne peut pas réaliser de surcharge de fonctions ou de méthodes ? Pour les débutants, on dira non, pour les autres, on peut toujours s’arranger avec Python...

Accélérez vos traitements en développant votre propre solution de parallélisation

Magazine
Marque
GNU/Linux Magazine
Numéro
244
Mois de parution
janvier 2021
Domaines
Résumé

Certains de vos traitements lancés par des scripts shell s'exécutent bien trop lentement à votre goût, alors que certaines tâches séquentielles pourraient en fait s'exécuter simultanément : cet article va vous montrer de façon détaillée comment les accélérer en les parallélisant.

CrossDev sous Eclipse

Magazine
Marque
GNU/Linux Magazine
HS n°
Numéro
112
Mois de parution
janvier 2021
Domaines
Résumé

Le développement logiciel nécessite l’utilisation d’outils pour l’écriture, la compilation et le débogage de code. La prise en main de ces outils n’est pas toujours évidente, alors lorsqu’on en maîtrise un, autant l’utiliser dans le maximum de cas. Eclipse permet cela et nous allons le voir dans le cas du développement embarqué.

L’édition des liens démystifiée

Magazine
Marque
GNU/Linux Magazine
Numéro
244
Mois de parution
janvier 2021
Domaines
Résumé

Parmi les étapes concourant à la fabrication d’un exécutable, l’édition des liens est certainement la plus méconnue. Elle est pourtant cruciale à plus d’un titre. Le choix entre édition statique et dynamique des liens a notamment des implications sur la facilité de développement, la sécurité et la performance.