फ्लास्क - SQLite

अजगर के पास इन-बिल्ट सपोर्ट है SQlite। SQlite3 मॉड्यूल को पायथन वितरण के साथ शिप किया गया है। पायथन में SQLite डेटाबेस का उपयोग करने पर एक विस्तृत ट्यूटोरियल के लिए, कृपया इस लिंक को देखें । इस खंड में हम देखेंगे कि कैसे एक फ्लास्क एप्लिकेशन SQLite के साथ इंटरैक्ट करता है।

एक SQLite डेटाबेस बनाएँ ‘database.db’ और इसमें छात्रों की तालिका बनाएं।

import sqlite3

conn = sqlite3.connect('database.db')
print "Opened database successfully";

conn.execute('CREATE TABLE students (name TEXT, addr TEXT, city TEXT, pin TEXT)')
print "Table created successfully";
conn.close()

हमारे फ्लास्क एप्लिकेशन में तीन हैं View कार्य करता है।

प्रथम new_student() फ़ंक्शन URL नियम के लिए बाध्य है (‘/addnew’)। यह एक HTML फाइल को प्रस्तुत करता है जिसमें छात्र सूचना प्रपत्र है।

@app.route('/enternew')
def new_student():
   return render_template('student.html')

के लिए HTML स्क्रिप्ट ‘student.html’ इस प्रकार है -

<html>
   <body>
      <form action = "{{ url_for('addrec') }}" method = "POST">
         <h3>Student Information</h3>
         Name<br>
         <input type = "text" name = "nm" /></br>
         
         Address<br>
         <textarea name = "add" ></textarea><br>
         
         City<br>
         <input type = "text" name = "city" /><br>
         
         PINCODE<br>
         <input type = "text" name = "pin" /><br>
         <input type = "submit" value = "submit" /><br>
      </form>
   </body>
</html>

जैसा कि देखा जा सकता है, प्रपत्र डेटा को पोस्ट किया गया है ‘/addrec’ URL जो बांधता है addrec() समारोह।

यह addrec() फ़ंक्शन द्वारा प्रपत्र के डेटा को पुनर्प्राप्त करता है POSTछात्र तालिका में विधि और आवेषण। सम्मिलित संचालन में सफलता या त्रुटि के अनुरूप संदेश को प्रदान किया जाता है‘result.html’

@app.route('/addrec',methods = ['POST', 'GET'])
def addrec():
   if request.method == 'POST':
      try:
         nm = request.form['nm']
         addr = request.form['add']
         city = request.form['city']
         pin = request.form['pin']
         
         with sql.connect("database.db") as con:
            cur = con.cursor()
            cur.execute("INSERT INTO students (name,addr,city,pin) 
               VALUES (?,?,?,?)",(nm,addr,city,pin) )
            
            con.commit()
            msg = "Record successfully added"
      except:
         con.rollback()
         msg = "error in insert operation"
      
      finally:
         return render_template("result.html",msg = msg)
         con.close()

की HTML स्क्रिप्ट result.html एक भागने वाला बयान शामिल है {{msg}} के परिणाम को प्रदर्शित करता है Insert ऑपरेशन।

<!doctype html>
<html>
   <body>
      result of addition : {{ msg }}
      <h2><a href = "\">go back to home page</a></h2>
   </body>
</html>

आवेदन में एक और शामिल है list() द्वारा प्रतिनिधित्व समारोह ‘/list’यूआरएल। यह आबाद करता है‘rows’ के रूप में MultiDictछात्रों की तालिका में सभी रिकॉर्ड वाली वस्तु। इस ऑब्जेक्ट को पास कर दिया गया हैlist.html टेम्पलेट।

@app.route('/list')
def list():
   con = sql.connect("database.db")
   con.row_factory = sql.Row
   
   cur = con.cursor()
   cur.execute("select * from students")
   
   rows = cur.fetchall(); 
   return render_template("list.html",rows = rows)

यह list.html एक टेम्प्लेट है, जो पंक्ति सेट पर पुनरावृत्त करता है और HTML तालिका में डेटा प्रदान करता है।

<!doctype html>
<html>
   <body>
      <table border = 1>
         <thead>
            <td>Name</td>
            <td>Address>/td<
            <td>city</td>
            <td>Pincode</td>
         </thead>
         
         {% for row in rows %}
            <tr>
               <td>{{row["name"]}}</td>
               <td>{{row["addr"]}}</td>
               <td> {{ row["city"]}}</td>
               <td>{{row['pin']}}</td>	
            </tr>
         {% endfor %}
      </table>
      
      <a href = "/">Go back to home page</a>
   </body>
</html>

अंततः ‘/’ URL नियम रेंडर करता है a ‘home.html’ जो आवेदन के प्रवेश बिंदु के रूप में कार्य करता है।

@app.route('/')
def home():
   return render_template('home.html')

यहाँ का पूरा कोड है Flask-SQLite आवेदन।

from flask import Flask, render_template, request
import sqlite3 as sql
app = Flask(__name__)

@app.route('/')
def home():
   return render_template('home.html')

@app.route('/enternew')
def new_student():
   return render_template('student.html')

@app.route('/addrec',methods = ['POST', 'GET'])
def addrec():
   if request.method == 'POST':
      try:
         nm = request.form['nm']
         addr = request.form['add']
         city = request.form['city']
         pin = request.form['pin']
         
         with sql.connect("database.db") as con:
            cur = con.cursor()
            
            cur.execute("INSERT INTO students (name,addr,city,pin) 
               VALUES (?,?,?,?)",(nm,addr,city,pin) )
            
            con.commit()
            msg = "Record successfully added"
      except:
         con.rollback()
         msg = "error in insert operation"
      
      finally:
         return render_template("result.html",msg = msg)
         con.close()

@app.route('/list')
def list():
   con = sql.connect("database.db")
   con.row_factory = sql.Row
   
   cur = con.cursor()
   cur.execute("select * from students")
   
   rows = cur.fetchall();
   return render_template("list.html",rows = rows)

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

इस स्क्रिप्ट को पायथन शेल से चलाएं और जैसे-जैसे विकास सर्वर चलने लगता है। यात्राhttp://localhost:5000/ ब्राउज़र में जो इस तरह एक सरल मेनू प्रदर्शित करता है -

क्लिक ‘Add New Record’ लिंक खोलने के लिए Student Information प्रपत्र।

फॉर्म फील्ड भरें और सबमिट करें। अंतर्निहित फ़ंक्शन छात्रों की तालिका में रिकॉर्ड सम्मिलित करता है।

होम पेज पर वापस जाएं और क्लिक करें ‘Show List’संपर्क। नमूना डेटा दिखाने वाली तालिका प्रदर्शित की जाएगी।