Ir al contenido principal

Integración de Bases de Datos en Flask: Facilidad y Versatilidad al Máximo

 


La integración de bases de datos es una de las capacidades más cruciales en el desarrollo de aplicaciones web. Flask, un micro-framework de Python, ofrece una flexibilidad increíble para trabajar con diferentes sistemas de gestión de bases de datos (DBMS). En este artículo, exploraremos cómo Flask facilita esta integración y presentaremos ejemplos prácticos para ilustrar su versatilidad y facilidad de uso.

¿Por Qué Elegir Flask para la Integración de Bases de Datos?

Flask es conocido por su simplicidad y flexibilidad, permitiendo a los desarrolladores crear aplicaciones web rápidamente y con poca sobrecarga. A diferencia de Django, que viene con su propio ORM (Object-Relational Mapping) y muchas funcionalidades integradas, Flask permite a los desarrolladores elegir las herramientas y bibliotecas que mejor se adapten a sus necesidades específicas.

Ventajas de Usar Flask para la Integración de Bases de Datos

  1. Flexibilidad: Flask no impone una estructura rígida, lo que permite a los desarrolladores seleccionar e integrar diversas bibliotecas de bases de datos según sus preferencias.
  2. Simplicidad: La curva de aprendizaje de Flask es más suave, especialmente para proyectos pequeños o desarrolladores que prefieren un enfoque minimalista.
  3. Extensibilidad: Con una amplia gama de extensiones disponibles, Flask puede ser fácilmente ampliado para incluir funcionalidades avanzadas sin complicaciones.

Ejemplos de Integración de Bases de Datos en Flask

1. Integración con SQLite usando SQLAlchemy

SQLAlchemy es una de las bibliotecas ORM más populares en el ecosistema de Python. Proporciona una forma poderosa y flexible de interactuar con las bases de datos.

Instalación

Primero, instalamos Flask y SQLAlchemy:

bash
pip install Flask SQLAlchemy

Configuración Básica

A continuación, configuramos Flask para usar SQLAlchemy con SQLite:

python
from flask import Flask from flask_sqlalchemy import SQLAlchemy app = Flask(__name__) app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///test.db' db = SQLAlchemy(app)

Creación de Modelos

Definimos un modelo de base de datos simple:

python
class User(db.Model): id = db.Column(db.Integer, primary_key=True) username = db.Column(db.String(80), unique=True, nullable=False) email = db.Column(db.String(120), unique=True, nullable=False) def __repr__(self): return f'<User {self.username}>'

Creación de la Base de Datos

Para crear la base de datos y las tablas, ejecutamos:

python
db.create_all()

2. Integración con PostgreSQL usando Flask-PyMongo

Si prefieres una base de datos NoSQL como MongoDB, Flask también puede manejarlo con facilidad usando Flask-PyMongo.

Instalación

Primero, instalamos Flask-PyMongo:

bash
pip install Flask-PyMongo

Configuración Básica

Configuramos Flask para conectarse a una base de datos MongoDB:

python
from flask import Flask from flask_pymongo import PyMongo app = Flask(__name__) app.config["MONGO_URI"] = "mongodb://localhost:27017/myDatabase" mongo = PyMongo(app)

Operaciones CRUD

A continuación, realizamos operaciones CRUD básicas:

python
@app.route('/add') def add_user(): user = {'username': 'John', 'email': 'john@example.com'} mongo.db.users.insert_one(user) return 'User added!' @app.route('/find') def find_user(): user = mongo.db.users.find_one({'username': 'John'}) return f'Found user: {user}'

3. Uso de Flask-SQLAlchemy con MySQL

Para proyectos que requieren el uso de bases de datos relacionales más robustas como MySQL, Flask-SQLAlchemy sigue siendo una excelente opción.

Instalación

Instalamos Flask-SQLAlchemy y el conector MySQL:

bash
pip install Flask-SQLAlchemy pymysql

Configuración Básica

Configuramos Flask para conectarse a una base de datos MySQL:

python
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+pymysql://username:password@localhost/mydatabase' db = SQLAlchemy(app)

Creación de Modelos y Operaciones CRUD

La creación de modelos y la realización de operaciones CRUD son similares a los ejemplos anteriores con SQLite, pero ahora usando MySQL como backend.

Conclusión

La capacidad de Flask para integrarse con una variedad de sistemas de gestión de bases de datos lo convierte en una opción excelente para desarrolladores que buscan flexibilidad y facilidad de uso. Ya sea que prefieras bases de datos SQL como SQLite y MySQL, o bases de datos NoSQL como MongoDB, Flask tiene las herramientas necesarias para ayudarte a construir aplicaciones web robustas y eficientes.

Implementa estas técnicas en tu próximo proyecto Flask y experimenta de primera mano la simplicidad y versatilidad que ofrece.

Comentarios

Entradas populares de este blog

Lenguajes de programación más conocidos en la historia de la computación

Los primeros lenguajes de programación eran difíciles de construir ya que éstos debían ser "desarrollados" a un nivel que la máquina entendiera directamente, es decir, la programación de computadoras de esta época dependía mucho de la máquina para la que se estaba trabajando y detectar un error o fallo en la programación no solo era complejo sino que demandaba mucho tiempo y esfuerzo. En 1946 Grace Murray Hopper, científica en sistemas y oficial de la marina estadounidense creo el FLOW-MATIC, considerado el primer lenguaje de programación útil para resolver problemas de usuarios comerciales.  Su desarrollo fue enfocado a la UNIVAC 1.  Este lenguaje de programación fue visto como de "alto nivel", fácil de usar por los científicos de la época.  FLOW-MATIC requería de un traductor (compilador) para ser interpretado por la máquina.   Con este lenguaje de programación se establece el concepto de programación basado en palabras del lenguaje natural y se da inicio al d

Enviar archivos por sftp con Python

Esta es una breve modificación a uno de los scripts creados con anterioridad y que consiste en enviar un archivo por  sftp.   La necesidad en concreto consistía en comparar ambos servidores local y remoto y validar qué archivo faltaba en el remoto que estuviera en el local para proceder a enviarlo y mantener el remoto actualizado. Este script se guarda con el nombre que quieras, le das permiso de ejecución y lo agregas en un crontab. import pysftp import os # Cambiar por la ruta donde se generan los archivos (Amsterdam) servidor_local = os.listdir(r'C:\proyecto\archivos') #print servidor_local # Cambiar por una ruta en Amsterdam, puede ser /tmp/res os.remove(r"c:\proyecto\res\archivos.txt") for archivos in servidor_local: # Cambiar por '/tmp/res/archivos.txt','a' local = open(r"c:\proyecto\res\archivos.txt",'a') print 'Archivo local: '+archivos local.write(str(archivos)+'\n')

Extraer logs de un rango de hora

Seguramente en sus trabajos se habrán visto en la necesidad de extraer logs en un rango dado de hora; es decir, desde las xx hasta las yy. Este proceso se puede hacer en linux utilizando varios comando como el grep, head, cut, etc. que combinados nos mostrarán lo que andamos buscando. Como en mi trabajo actual es bastante común esta actividad me he dado a la tarea de crear un script bash para ello. Este es el código fuente que obviamente pueden mejor y/o adaptar a sus necesidades: #!/bin/bash ## Rango v.1.0 ## Genera un log con un rango de hora ingresado ## Autor: Manuel Gonzalez ## http://maengora.blogspot.com # Forma de usar el script echo "Con bash: ./rango.sh " # Solicito la hora inicial y la almaceno en la variable HORA_INICIAL echo -n "Hora incial hh:mm " read HORA_INICIAL # Solicito hora final echo -n "Hora final hh:mm " read HORA_FINAL # Solicito el nombre del log de donde voy a extraer la informacion echo -n "Nombre del log a analizar &qu