फ्लास्क - SQLAlchemy

डेटाबेस में CRUD संचालन करने के लिए फ्लास्क वेब अनुप्रयोगों में कच्चे एसक्यूएल का उपयोग करना थकाऊ हो सकता है। बजाय,SQLAlchemy, पायथन टूलकिट एक शक्तिशाली है OR Mapperयह एप्लिकेशन डेवलपर्स को SQL की पूरी शक्ति और लचीलापन देता है। फ्लास्क- SQLAlchemy फ्लास्क एक्सटेंशन है जो आपके फ्लास्क एप्लिकेशन के लिए SQLAlchemy के लिए समर्थन जोड़ता है।

What is ORM (Object Relation Mapping)?

अधिकांश प्रोग्रामिंग लैंग्वेज प्लेटफ़ॉर्म ऑब्जेक्ट ओरिएंटेड हैं। दूसरी ओर RDBMS सर्वर में डेटा तालिकाओं के रूप में संग्रहीत किया जाता है। ऑब्जेक्ट रिलेशन मैपिंग अंतर्निहित RDBMS टेबल संरचना में ऑब्जेक्ट पैरामीटर्स की मैपिंग की एक तकनीक है। एक ORM एपीआई कच्चे SQL बयान लिखने के लिए बिना CRUD संचालन करने के लिए तरीके प्रदान करता है।

इस खंड में, हम फ्लास्क-एसक्यूएलकेमी की ओआरएम तकनीकों का अध्ययन करने और एक छोटे से वेब एप्लिकेशन का निर्माण करने जा रहे हैं।

Step 1 - फ्लास्क-SQLAlchemy एक्सटेंशन स्थापित करें।

pip install flask-sqlalchemy

Step 2 - आपको इस मॉड्यूल से SQLAlchemy वर्ग आयात करने की आवश्यकता है।

from flask_sqlalchemy import SQLAlchemy

Step 3 - अब एक फ्लास्क एप्लिकेशन ऑब्जेक्ट बनाएं और उपयोग किए जाने वाले डेटाबेस के लिए URI सेट करें।

app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///students.sqlite3'

Step 4- फिर पैरामीटर के रूप में एप्लिकेशन ऑब्जेक्ट के साथ SQLAlchemy वर्ग का ऑब्जेक्ट बनाएं। इस ऑब्जेक्ट में ORM संचालन के लिए सहायक कार्य हैं। यह एक माता-पिता मॉडल वर्ग भी प्रदान करता है जिसके उपयोग से उपयोगकर्ता परिभाषित मॉडल घोषित किए जाते हैं। नीचे स्निपेट में, एstudents मॉडल बनाया गया है।

db = SQLAlchemy(app)
class students(db.Model):
   id = db.Column('student_id', db.Integer, primary_key = True)
   name = db.Column(db.String(100))
   city = db.Column(db.String(50))  
   addr = db.Column(db.String(200))
   pin = db.Column(db.String(10))

def __init__(self, name, city, addr,pin):
   self.name = name
   self.city = city
   self.addr = addr
   self.pin = pin

Step 5 - URI में उल्लिखित डेटाबेस बनाने / उपयोग करने के लिए, चलाएँ create_all() तरीका।

db.create_all()

Session की वस्तु SQLAlchemy के सभी दृढ़ता संचालन का प्रबंधन करता है ORM वस्तु।

निम्नलिखित सत्र विधियां CRUD संचालन करती हैं -

  • db.session.add(मॉडल ऑब्जेक्ट) - मैप किए गए तालिका में एक रिकॉर्ड सम्मिलित करता है

  • db.session.delete(मॉडल ऑब्जेक्ट) - तालिका से रिकॉर्ड हटाता है

  • model.query.all() - तालिका से सभी रिकॉर्ड को पुनः प्राप्त (चयन क्वेरी के अनुसार)।

आप फ़िल्टर विशेषता का उपयोग करके पुनर्प्राप्त रिकॉर्ड सेट के लिए एक फ़िल्टर लागू कर सकते हैं। उदाहरण के लिए, रिकॉर्ड को पुनः प्राप्त करने के लिएcity = ’Hyderabad’ छात्रों की तालिका में, निम्नलिखित कथन का उपयोग करें -

Students.query.filter_by(city = ’Hyderabad’).all()

इस पृष्ठभूमि के साथ, अब हम अपने आवेदन में छात्र डेटा जोड़ने के लिए कार्य प्रदान करेंगे।

आवेदन का प्रवेश बिंदु है show_all() के लिए बाध्य समारोह ‘/’यूआरएल। छात्रों के टेबल का रिकॉर्ड सेट HTML टेम्पलेट के पैरामीटर के रूप में भेजा जाता है। टेम्पलेट में सर्वर साइड कोड एचटीएमएल टेबल फॉर्म में रिकॉर्ड प्रस्तुत करता है।

@app.route('/')
def show_all():
   return render_template('show_all.html', students = students.query.all() )

टेम्पलेट की HTML स्क्रिप्ट (‘show_all.html’) इस तरह है -

<!DOCTYPE html>
<html lang = "en">
   <head></head>
   <body>
      <h3>
         <a href = "{{ url_for('show_all') }}">Comments - Flask 
            SQLAlchemy example</a>
      </h3>
      
      <hr/>
      {%- for message in get_flashed_messages() %}
         {{ message }}
      {%- endfor %}
		
      <h3>Students (<a href = "{{ url_for('new') }}">Add Student
         </a>)</h3>
      
      <table>
         <thead>
            <tr>
               <th>Name</th>
               <th>City</th>
               <th>Address</th>
               <th>Pin</th>
            </tr>
         </thead>

         <tbody>
            {% for student in students %}
               <tr>
                  <td>{{ student.name }}</td>
                  <td>{{ student.city }}</td>
                  <td>{{ student.addr }}</td>
                  <td>{{ student.pin }}</td>
               </tr>
            {% endfor %}
         </tbody>
      </table>
   </body>
</html>

उपरोक्त पृष्ठ में हाइपरलिंक है ‘/new’ URL मैपिंग new()समारोह। जब क्लिक किया जाता है, तो यह एक छात्र सूचना प्रपत्र खोलता है। डेटा उसी URL में पोस्ट किया गया हैPOST तरीका।

new.html

<!DOCTYPE html>
<html>
   <body>
      <h3>Students - Flask SQLAlchemy example</h3>
      <hr/>
      
      {%- for category, message in get_flashed_messages(with_categories = true) %}
         <div class = "alert alert-danger">
            {{ message }}
         </div>
      {%- endfor %}
      
      <form action = "{{ request.path }}" method = "post">
         <label for = "name">Name</label><br>
         <input type = "text" name = "name" placeholder = "Name" /><br>
         <label for = "email">City</label><br>
         <input type = "text" name = "city" placeholder = "city" /><br>
         <label for = "addr">addr</label><br>
         <textarea name = "addr" placeholder = "addr"></textarea><br>
         <label for = "PIN">City</label><br>
         <input type = "text" name = "pin" placeholder = "pin" /><br>
         <input type = "submit" value = "Submit" />
      </form>
   </body>
</html>

जब HTTP विधि को POST के रूप में पाया जाता है, तो छात्रों के टेबल में फॉर्म डेटा जोड़ा जाता है और एप्लिकेशन जोड़ा गया होमपेज पर वापस आ जाता है।

@app.route('/new', methods = ['GET', 'POST'])
def new():
   if request.method == 'POST':
      if not request.form['name'] or not request.form['city'] or not request.form['addr']:
         flash('Please enter all the fields', 'error')
      else:
         student = students(request.form['name'], request.form['city'],
            request.form['addr'], request.form['pin'])
         
         db.session.add(student)
         db.session.commit()
         
         flash('Record was successfully added')
         return redirect(url_for('show_all'))
   return render_template('new.html')

नीचे दिए गए आवेदन का पूरा कोड है (app.py)

from flask import Flask, request, flash, url_for, redirect, render_template
from flask_sqlalchemy import SQLAlchemy

app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///students.sqlite3'
app.config['SECRET_KEY'] = "random string"

db = SQLAlchemy(app)

class students(db.Model):
   id = db.Column('student_id', db.Integer, primary_key = True)
   name = db.Column(db.String(100))
   city = db.Column(db.String(50))
   addr = db.Column(db.String(200)) 
   pin = db.Column(db.String(10))

def __init__(self, name, city, addr,pin):
   self.name = name
   self.city = city
   self.addr = addr
   self.pin = pin

@app.route('/')
def show_all():
   return render_template('show_all.html', students = students.query.all() )

@app.route('/new', methods = ['GET', 'POST'])
def new():
   if request.method == 'POST':
      if not request.form['name'] or not request.form['city'] or not request.form['addr']:
         flash('Please enter all the fields', 'error')
      else:
         student = students(request.form['name'], request.form['city'],
            request.form['addr'], request.form['pin'])
         
         db.session.add(student)
         db.session.commit()
         flash('Record was successfully added')
         return redirect(url_for('show_all'))
   return render_template('new.html')

if __name__ == '__main__':
   db.create_all()
   app.run(debug = True)

पायथन शेल से स्क्रिप्ट चलाएँ और दर्ज करें http://localhost:5000/ ब्राउज़र में।

दबाएं ‘Add Student’ खोलने के लिए लिंक Student information प्रपत्र।

फॉर्म भरें और सबमिट करें। होम पेज सबमिट किए गए डेटा के साथ फिर से दिखाई देता है।

हम आउटपुट को नीचे दिखाए अनुसार देख सकते हैं।