บทที่ 7 ขั้นตอน การค้นหาข้อมูล และแสดงข้อมูลจากฐานข้อมูลบนหน้าเว็บ ด้วย Python Flask Framework

Python (ไพธอน) สามารถค้นหาข้อมูล ด้วยคำสั่งภาษา SQL (เอส-คิว-แอล) และยังสามารถแสดงผลจาก keyword ที่เราป้อนคำค้นหาลงไปได้ โดยใช้ Flask (แฟลก) 

 

ขั้นตอนที่ 1 สร้างแบบฟอร์มสำหรับการรับค่าข้อมูล เพื่อทำการค้นหา ที่หน้า search.html

<body>
    <form action = "{{ url_for('showsearchs') }}" method = "POST">
         <table border="0" width="50"  align="center">
         <thead>
          <tr align="center"></tr>
            <td width="50%" align="center"><input type = "text" name = "search" /></td>
            <td width="50%"><input type = "submit" value = "ค้นหา" /></td>
         </thead>
         </table>
    </form>
</body>

ขั้นตอนที่ 2 ให้เราสร้างฟอร์มหน้าจอเพื่อดึงข้อมูลออกมาแสดง ที่หน้า showsearch.html
method ส่งค่า rows มาที่ showsearch.html ทำการ for วนลูบ ค่า row ด้วยภาษา python

<body>
   <table border="1" 1cellspacing="5" width="80%" height="5" align="center">
         <a href = "/">กลับหน้าหลัก</a>

      <thead>
         <td align="center">รหัส</td>
         <td align="center">ชื่อ</td>
         <td align="center">นามสกุล</td>
         <td align="center">สีที่ชอบ</td>
         <td colspan="2" align="center" width="10%">เครื่องมือ</td>
      </thead>

      {% for row in rows %}
         <tr>
            <td >{{ row[0] }}</td>
            <td>{{ row[1] }}</td>
            <td>{{ row[2] }}</td>
            <td>{{ row[3] }}</td>
            <td>  <form action="/iddel/{{ row[0] }}" method="post"> <input type="submit" value="ลบข้อมูล" /> </form></td>
             <td><form action="/enteredit/{{ row[0] }}" method="post"> <input type="submit" value="แก้ไข" /> </form></td>
         </tr>
      {% endfor %}

   </table>
</body>

ขั้นตอนที่ 3 สร้าง method การรับค่าจากฟอร์ม แล้วใช้คำสั่งภาษา SQL ในการค้นหาข้อมูล หลังจากนั้นเก็บไว้ในตัวแปร rows และทำการ

@app.route('/showsearchs' , methods=['POST', 'GET'])
def showsearchs():
    if request.method == 'POST':
        key = request.form['search']
        try:
            con = p.connect(host='127.0.0.1', database='test',user='postgres',password='123456')
            cur = con.cursor()
            sql = "SELECT * FROM table_test_1 WHERE favorite_color = '%s' OR name_first= '%s' OR name_last= '%s'" % (key,key,key)
            sql = sql.encode('utf-8')
            try:
                cur.execute(sql)
                rows = cur.fetchall()
                return render_template("showsearch.html", rows=rows)
            except:
                con.rollback()
                print('ผิดพลาด')
        except p.DatabaseError:
            print('Error %s' % p.DatabaseError)


ภาพตัวอย่างจากการรันโปรแกรม


ผลลัพธ์

ข้อมูลทั้งหมดนี้เป็นส่วนหนึ่งของการ เขียน Python ที่มีการเชื่อมต่อกับฐานข้อมูล บทเรียนที่ท่านได้ศึกษามา หวังว่าจะเป็นประโยชน์ไม่มากก็น้อย

หัวเรื่อง
การค้นหาข้อมูลจากฐานข้อมูลบนหน้าเว็บ ด้วย Python Flask Framework
หมวดหมู่
Python Framework Flask, Python Framework Flask
ฮิต
1112
ผู้สร้างเอกสาร
anawatj
วันที่สร้างเอกสาร
2023-09-27 19:39:03
รายละเอียด

เขียน Python Flask Framework ค้นหาข้อมูล และ แสดงข้อมูลจากฐานข้อมูลบนหน้าเว็บ 

search-flask.zip

ประเภทไฟล์ zip

ขนาดไฟล์ 1.75 KB

ผู้อัพโหลดไฟล์ anawatj

วันที่อัพโหลด 2023-09-27 12:35:19


 

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
SQL JOIN: การรวมข้อมูลจากหลายตารางในฐานข้อมูล
โดย witsarutt000 พฤ 14 มี.ค. 2024 4:07 pm บอร์ด SQL Knowledge
1
166
พฤ 14 มี.ค. 2024 5:44 pm โดย Sirayu View Topic SQL JOIN: การรวมข้อมูลจากหลายตารางในฐานข้อมูล
PHP การเปลี่ยนแปลงที่สร้างปรากฏการณ์ในโลกของเว็บ
โดย witsarutt000 พฤ 14 มี.ค. 2024 11:17 am บอร์ด PHP Knowledge
0
125
พฤ 14 มี.ค. 2024 11:17 am โดย witsarutt000 View Topic PHP การเปลี่ยนแปลงที่สร้างปรากฏการณ์ในโลกของเว็บ
ปัญหา Harddisk ขึ้น 100% เวลาเซฟไฟล์ หรือภาพ จะค้่างที่หน้าแท๊บ Expolorer
โดย Thanavat_n พ 13 มี.ค. 2024 11:02 am บอร์ด ถาม - ตอบ คอมพิวเตอร์
5
270
พ 13 มี.ค. 2024 1:34 pm โดย Thanavat_n View Topic ปัญหา Harddisk ขึ้น 100% เวลาเซฟไฟล์ หรือภาพ จะค้่างที่หน้าแท๊บ Expolorer
ตู้รองเท้า ไอเท็มวิเศษช่วยจัดระเบียบคอลเลกชันรองเท้าคู่โปรด
โดย @Foretoday อ 12 มี.ค. 2024 1:46 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
184
อ 12 มี.ค. 2024 1:46 pm โดย @Foretoday View Topic ตู้รองเท้า ไอเท็มวิเศษช่วยจัดระเบียบคอลเลกชันรองเท้าคู่โปรด
แนะนำสถานที่น่าเที่ยวในจังหวัดชุมพรพร้อมวิธีการเดินทาง
โดย witsarutt000 จ 11 มี.ค. 2024 6:14 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
142
จ 11 มี.ค. 2024 6:14 pm โดย witsarutt000 View Topic แนะนำสถานที่น่าเที่ยวในจังหวัดชุมพรพร้อมวิธีการเดินทาง
ย้าย VM ข้าม Host ด้วย scp กรณีศึกษา Vmware ESXI
โดย mindphp อ 10 มี.ค. 2024 4:36 am บอร์ด Linux - Web Server
0
239
อ 10 มี.ค. 2024 4:36 am โดย mindphp View Topic ย้าย VM ข้าม Host ด้วย scp กรณีศึกษา Vmware ESXI
IP และ vpn (VMware)
โดย ballmykids อ 10 มี.ค. 2024 2:35 am บอร์ด ถาม - ตอบ คอมพิวเตอร์
2
203
จ 11 มี.ค. 2024 3:19 pm โดย ballmykids View Topic IP และ vpn (VMware)
แบบนี้ต้องทำยังไง ในกรณีที่ Server เดิมเราได้ทำการ Raid 1 กับ HDD 2 ลูกแรกแล้ว
โดย Anonymous ศ 08 มี.ค. 2024 7:02 am บอร์ด ถาม - ตอบ คอมพิวเตอร์
1
166
ศ 08 มี.ค. 2024 8:12 pm โดย mindphp View Topic แบบนี้ต้องทำยังไง ในกรณีที่ Server เดิมเราได้ทำการ Raid 1 กับ HDD 2 ลูกแรกแล้ว