ตัวอย่างการใช้งาน SQLite บน Android ตอนที่ 1
วันนี้จะมาพูดถึงเรื่องของ Android SQLite กันนะครับ ตัวแอพพลิเคชันที่ทำเป็น Demo ก็เสร็จนานแล้ว เหลือแต่ช่วงเขียนบทความนี่แหละ ยังหาเวลาเขียนลงตัวไม่ได้ซักที จะว่าไปเรื่องนี้น่าจะเป็นเรื่อง Classic และเป็นเรื่องที่จำเป็นที่นักพัฒนาแอพพลิเคชันแอนดรอยส์ทุกคนจำเป็นต้องรู้ครับ เพราะมันคือการติดต่อฐานข้อมูล เชื่อมต่อฐานข้อมูลกับแอพพลิเคชันของเรา นั่นเอง
SQLite คืออะไร?
SQLite มันก็คือ Library ตัวนึงที่มีขนาดเล็กมาก คอยจัดการ Database ให้กับเรา โดยใช้ Syntax SQL เหมือนกับ MySQL เลย Data Type ที่ SQLite ซับพอร์ตก็คือ TEXT
เหมือนกับ String ใน Java, INTEGER
เก็บค่าตัวเลขเหมือนกับ long
และ REAL
เก็บค่าเหมือนกับ double
สำหรับใน SQLite ใน Android นั้นมันติดมากับเครื่อง Android ทุกเครื่อง เวลาเขียนแอพเพื่อเชื่อมต่อกับ SQLite ก็ไม่จำเป็นต้องโหลดหรือทำอะไรเพิ่ม เพราะว่าทาง Android นั้นก็ได้เตรียม Class ต่างๆ อำนวยความสะดวกให้เราแล้ว
สำหรับที่อยู่ เวลาเก็บ Database จะถูกเก็บไว้ที่ data/data/PACKAGE_NAME/databases/DB_NAME
Step 1 : Create Project
ไม่พูดมาก เรามาเริ่มสร้างโปรเจ็คกันเลยดีกว่าครับ สำหรับโปรเจ็คนี้เป้าหมายคือ การใช้งาน SQLite และสามารถ CREATE, UPDATE, DELETE ฐานข้อมูลได้ ส่วนตัวแอพพลิเคชันจะประกอบไปด้วย
- หน้า MainActivity สำหรับแสดง List รายชื่อเพื่อนต่างๆของเรา
- หน้า AddFriendActivity สำหรับหน้ากรอกข้อมูล เพื่อเพิ่มเพื่อนเข้าสู่ฐานข้อมูล
- หน้า DetailActivity สำหรับไว้ดูรายละเอียดของเพื่อนคนนั้นๆ
เมื่อวาดออกมาเป็น Diagram ก็จะได้หน้าตาประมาณนี้
ผมไม่พูดถึงวิธีการสร้างโปรเจ็คนะครับ สมมติว่าทุกคนสร้างโปรเจ็คเสร็จแล้ว ต่อมา ดูโครงสร้างของ Database ที่เราจะสร้างกัน เนื่องจากแอพพลิเคชันนี้เป็นแอพสำหรับดูรายละเอียดของเพื่อน ฉะนั้นโครงสร้างของ ฐานข้อมูล ก็จะเป็นลักษณะนี้
ต่อมาก็สร้างคลาส Model ตั้งชื่อว่า Friend.java
ทำการสร้าง Constructor และ Getter, Setter แบบนี้
Constructor ก็เอาไว้สำหรับ Init ค่า Friend ครับ เวลาสร้างออปเจ็ค Friend ขึ้นมา เช่น id, ชื่อ, นามสกุล, เบอร์โทร, อีเมล์และรายละเอียดต่างๆ
ต่อมา เราก็จะทำการสร้างคลาส เพื่อไว้จัดการ Database ของเรา ผมสร้างคลาสชื่อว่า DBHelper
และทำการ extends คลาส SQLiteOpenHelper
เจ้าคลาสที่เราทำการ extends นี้มันจะเป็นคลาสที่เอาไว้ช่วยให้เราสร้างฐานข้อมูล , อัพเดทฐานข้อมูลครับ ทำการ implements เมธอด และสร้าง Constructor ดังนี้
จากด้านบน Constructor จะทำการเรียก super จากนั้นส่ง arguments เป็น Context
, ชื่อฐานข้อมูล, CursorFactory, และ เวอร์ชันของ Database ตามลำดับ ส่วนเมธอด onCreate()
และ onUpgrade()
จะเอาไว้สร้างฐานข้อมูลของเรา และอัพเกรดฐานข้อมูลครับ
เมธอด onCreate()
ผมก็ทำการสร้าง SQL Command จากนั้นก็สั่ง db.execSQL(String)
เพื่อทำการสร้าง Table จาก String และเมธอด onUpgrade()
สำหรับเมื่อมีการเปลี่ยนโครงสร้าง Database หรือมีการเปลี่ยนเวอร์ชัน ก็จะทำการ Drop Table และเรียกเมธอด onCreate(db)
เพื่อสร้างใหม่
จะเห็นได้ว่า ที่ onCreate()
ผมสั่ง SQL Command เป็น String แบบ hard code เลย ดูแล้วไม่สะดวก หากต้องการแก้ไข หรือเปลี่ยนแปลง Field ต่างๆ ผมก็เลยประกาศเป็นตัวแปรแทน โดยไปเพิ่มตัวแปรที่ model Friend เป็นแบบนี้
เพื่ออะไร? เพื่อสร้างเป็นค่าคงที่สำหรับเก็บชื่อฐานข้อมูล เก็บชื่อ table และก็เก็บค่า column ในฐานข้อมูล กลับมาที่ไฟล์ DBHelper
คราวนี้จากใช้ SQL แบบ hard code ก็เปลี่ยนมาใช้ String.format
แบบนี้
เครื่องหมาย %s ตัวแรก ก็คือ Friend.TABLE, %s ตัวสองคือ Friend.Column.ID ไล่ไปเรื่อยๆ
สุดท้ายไฟล์ DBHelper
ก็จะได้แบบนี้
ทีนี้เมื่อเราสร้าง DBHelper
เสร็จแล้ว ต่อไปเราจะใช้มันยังไง?
Step 2 : สร้าง ListView
ต่อมาก็จะทำการสร้าง Layout สำหรับแสดงรายชื่อเพื่อนนะครับ แต่ว่าผมจะใช้การ extends ListActivity
ฉะนั้นก็เลยไม่จำเป็นต้องสร้างไฟล์เลเอาท์ ก็ข้ามไปสร้าง MainActivity.java
เลย หรือจะใช้คลาสเดิมก็ได้ ทำการ extends ListActivity
ครับ เพื่อจะแสดง ListView เฉยๆ ตัวคลาสจะได้ดังนี้
จะเห็นได้ว่าโครงสร้างของคลาส ไม่มีอะไรมาก ก็คือจะทำการสร้าง ListView ด้วย ArrayAdapter
จากรายชื่อเพื่อนในฐานข้อมูล แต่ว่าตอนนี้ยังไม่ได้ Query อะไร ก็จะใส่เป็น lists แบบไม่มีอะไรไปก่อน android.R.layout.simple_list_item_1
นั้นเป็น Layout ของทาง Android นะครับ
สำหรับใครไม่รู้เรื่อง ListActivity สามารถอ่านเพิ่มได้ที่บทความนี้ครับ การสร้าง ListView แบบง่ายๆ
Step 3: Query SQLite
มาถึงการ Query ฐานข้อมูลกันบ้าง กลับมาที่คลาส DBHelper
ต่อครับ ผมจะทำการสร้างเมธอดขึ้นมาใหม่ เพื่อทำการ Query จากนั้นก็จะส่งข้อมูลกลับไปเป็น List<String>
เพื่อเอาไปแสดงใน ListView
หน้า MainActivity
ก็เลยทำการตั้งชื่อเมธอดว่า getFriendList()
จะเห็นได้ว่า ผมเริ่มทำการสร้าง SQL Statement เพื่อจะ Query จากฐานข้อมูล เริ่มแรกให้ this.getWriteableDatabase()
เพื่อให้เข้าถึงการอ่านฐานข้อมูลนั่นเอง จากนั้นก็ทำการ Query ด้วยคำสั่ง query
โดยส่งพารามิเตอร์เป็น ชื่อ Table ส่วนอันอื่นเป็น null คือ Query ข้อมูลจาก Table ชื่อ Friend ทั้งหมด มีค่าเท่ากับ SELECT * FROM friend
จากนั้นก็วนลูป ส่งค่า List<String>
กลับไปนั่นเอง
Note: สำหรับ
cursor.getXXXX(int)
คือการ get ค่าด้วย Type ที่กำหนด ใน Column ตำแหน่งต่างๆ เช่นcursor.getLong(0)
ก็จะทำการ get ค่า id,getString(1)
ก็จะทำการ get ค่า first_name ออกมา และgetString(2)
ก็จะทำการ get ค่า last_name ออกมาตามลำดับ
เท่านี้ในส่วนของการ Query รายชื่อเพื่อน ก็เรียบร้อย ต่อไปก็กลับไปที่คลาส MainActivity
Step 4: โชว์รายชื่อเพื่อน
เมื่อเราทำการสร้างเมธอดใน DBHelper
เสร็จแล้ว ต่อไปเราก็จะเรียกใช้มันที่ MainActivity
กันครับ
ที่เมธอด onCreate()
ทำการสร้าง new instance ของ DBHelper จากนั้นก็เรียกเมธอด getFriendList()
เพื่อส่งค่ากลับมาที่ตัวแปร friends
ทดสอบรันโปรแกรมครับ จะเห็นความว่างเปล่า ไม่มีอะไร ฮ่าๆ :D
ตอนนี้เรายังไม่รู้จักวิธีการ INSERT, UPDATE, DELETE ฉะนั้นก็ใช้วิธี เอา db ที่ผมสร้างไว้ devahoy_friends.db เอาไปใช้ก่อน โดยเปิด DDMS จากนั้นเลือกไปที่ data/data/com.devahoy.sample.ahoysqlite/databases
แล้วก็กด Push a File into Device นำไฟล์ devahoy_friends.db
ไปใส่ จากนั้นทดสอบ รันแอพพลิเคชันครับ จะเห็นรายชื่อเพื่อนขึ้นมาแล้ว
ส่วนการ INSERT, UPDATE, DELETE ต่อ Part 2 ที่นี่ครับ สำหรับบทความนี้ขอจบเท่านี้ก่อน
- Authors
-
Chai Phonbopit
เป็น Web Dev ในบริษัทแห่งหนึ่ง ทำงานมา 10 ปีกว่าๆ ด้วยภาษาและเทคโนโลยี เช่น JavaScript, Node.js, React, Vue และปัจจุบันกำลังสนใจในเรื่องของ Blockchain และ Crypto กำลังหัดเรียนภาษา Rust