Ir al contenido principal

Python + Flask + Persistance VI

Sqlalchemy

Install
In the environment

pip install flask-sqlalchemy



Create model
Create file in root path to define the class. Ex. model.py

from datetime import datetime
from ict import db

class Ticket(db.Model):
id = db.Column(db.Integer, primary_key=True)
signum = db.Column(db.String(10), nullable=True)
comments = db.Column(db.String(255), nullable=True)

Add methos to do the queries
       @staticmethod
def newest(num):
return Ticket.query.order_by(desc(Ticket.signum)).limit(num)

def __repr__(self):
return "<Ticket '{}' : '{}'> ".format(self.signum, self.comments)

Option in query
.limit
.first_or_404()
.get_or_404()


SQLITE
In the console at environment

  • python
  •  from ict import db     ict is the controller ict.py
  • from model import Ticket     refers to the file model.py where the class is define
  • db.create_all()   create DB

Controller


  • Import

import os
from flask_sqlalchemy import SQLAlchemy
import model      the file with the object/class definition


  • Define the DB

basedir = os.path.abspath( os.path.dirname(__file__) )

app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///' + os.path.join(basedir, 'ict_dev.db')
db = SQLAlchemy(app)


  • Use DB in 

ticket = model.Ticket(signum=signum, comments=comments)
db.session.add(ticket)


  • In the model
from datetime import datetime

from sqlalchemy import desc
from ict import db

class Ticket(db.Model):
id = db.Column(db.Integer, primary_key=True)
signum = db.Column(db.String(10), nullable=True)
comments = db.Column(db.String(255), nullable=True)
engineer_id = db.Column(db.Integer, db.ForeignKey('engineer.id'), nullable=False)

@staticmethod
def newest(num):
return Ticket.query.order_by(desc(Ticket.signum)).limit(num)

def __repr__(self):
return "<Ticket '{}' : '{}'> ".format(self.signum, self.comments)


  • Use the method from model to do the query

@app.route('/show_tickets')
def show_tickets():
return render_template('show_tickets.html', new_tickets=model.Ticket.newest(5))



Simple queries 


  • Ticket.query.get(1)
  • Ticket.query.all()
  • Ticket.query.filter_by( attribute="value" ).first()








Comentarios

Entradas populares de este blog

C# Using tabs

To use tabs in C# use the TabContainer element from AjaxControlToolkit Include AjaxControlToolkit  Include in the Web.config file, inside the tag <system.web> the following code  <pages>       <controls>         <add tagPrefix="ajaxCTK" namespace="AjaxControlToolkit" assembly="AjaxControlToolkit"/>       </controls>     </pages>   Include TabContainer element First  include TabContainer element that is the section where all the tabs will be displayed. <ajaxCTK:TabContainer ID="TabContainerUpdate" runat="server"                 Height="800"                 CssClass="ajax__tab_style"> </ajaxCTK:TabContainer> Second per each tab include the following code corresponding to each ...

Rails - Basic Steps III

pValidations Validations are a type of ActiveRecord Validations are defined in our models Implement Validations Go to   root_app/app/models Open files  *.rb for each model Mandatory field validates_presence_of   :field Ex:   validates_presence_of    :title Classes The basic syntax is class MyClass        @global_variable                def my_method              @method_variable        end end Create an instance myInstance = MyClass.new Invoke a mehod mc.my_method class() method returns the type of the object In Ruby, last character of method define the behavior If ends with a question -> return a boolean value If ends with an exclamation -> change the state of the object Getter / Setter method def global_variable       return @global_variable end ...

Python create package

Create a root folder Create a sub-folder "example_pkg" that contains the funtionallity packaging_tutorial/ example_pkg/ __init__.py In the root folder create the following structure  packaging_tutorial/ example_pkg/ __init__.py tests/ setup.py LICENSE README.md in the setup.py contains the configuration of the packages your package is found by find_packages() import setuptools with open ( "README.md" , "r" ) as fh : long_description = fh . read () setuptools . setup ( name = "example-pkg-YOUR-USERNAME-HERE" , # Replace with your own username version = "0.0.1" , author = "Example Author" , author_email = "author@example.com" , description = "A small example package" , long_description = long_description , long_description_content_type = "text/markdown" , url = "https://github.com/pypa/sam...