SQLite trong Flutter là gì?

  • SQLite là cơ sở dữ liệu quan hệ nhúng (embedded relational database) có các đặc điểm quan trọng:

    • Không cần server: Dữ liệu được lưu trực tiếp trong file .db trên thiết bị

    • Hỗ trợ đầy đủ ACID: Đảm bảo tính toàn vẹn dữ liệu

    • Hiệu suất cao: Xử lý tốt với lượng dữ liệu vừa và lớn

    • Hỗ trợ SQL đầy đủ: Các câu lệnh SELECT, INSERT, UPDATE, DELETE

Kiến Trúc Ứng Dụng

Ứng dụng được thiết kế theo mô hình 3 lớp:

  1. Presentation Layer: Giao diện người dùng (UI) xây dựng bằng Flutter Widgets

  2. Business Logic Layer: Xử lý nghiệp vụ, quản lý trạng thái (Provider/Bloc)

  3. Data Access Layer: Tương tác với cơ sở dữ liệu SQLite

Các Thao Tác Cơ Bản Với SQLite

Operation SQL Command Mô Tả
CREATE INSERT Thêm dữ liệu mới
READ SELECT Đọc dữ liệu
UPDATE UPDATE Sửa dữ liệu
DELETE DELETE Xóa dữ liệu

Ứng dụng vào Project Note-App

Model Note

Tạo class DatabaseHelper

Chỉnh sửa lại hàm loadNotes

About the Author

Tấn Phước

View all author's posts

Leave a Comment

Your email address will not be published. Required fields are marked *

Bài viết khác

Kanban

1. Kanban là gì? Kanban là một phương pháp quản lý công việc trực quan, giúp bạn theo dõi tiến độ từng nhiệm vụ. Kanban bắt nguồn từ Nhật Bản, ban đầu được Toyota dùng để quản lý dây chuyền sản xuất, nhưng ngày nay được áp dụng rộng rãi trong các lĩnh vực như […]

Scum

1. Scrum là gì? Scrum là một khung làm việc (framework) giúp các nhóm làm việc cùng nhau để phát triển sản phẩm một cách linh hoạt và hiệu quả. Nó thuộc phương pháp Agile – đề cao sự thích nghi, cộng tác và cải tiến liên tục trong quá trình làm việc. 2. Các […]

So sánh Realm, Hive, Sqflite, và Drift

So sánh Tiêu chí Realm Hive Sqflite Drift Mức độ phổ biến Tăng nhanh (Meta hỗ trợ) Rất phổ biến Rất phổ biến Trung bình (cộng đồng ổn định) Dễ sử dụng, dễ tích hợp Trung bình (cần setup Realm SDK) ★ Rất dễ (NoSQL, không cần SQL) Trung bình (phải viết SQL tay) Trung […]

Testing

I. Testing là gì? Testing (kiểm thử phần mềm) là quá trình đánh giá một hệ thống phần mềm để xác định xem sản phẩm có đáp ứng các yêu cầu được đặt ra hay không, và nhằm phát hiện lỗi nếu có. Testing là một phần quan trọng trong vòng đời phát triển phần […]

Application security

Ứng dụng bảo mật là gì? Application Security (Bảo mật ứng dụng) là quá trình bảo vệ ứng dụng khỏi các lỗ hổng và tấn công từ các mối đe dọa bên ngoài. Quá trình này bao gồm các biện pháp bảo vệ trong suốt vòng đời phát triển phần mềm (SDLC): từ thiết kế, […]

MVC/MVP

1. Giới thiệu chung Trong phát triển phần mềm, việc tổ chức mã theo mô hình kiến trúc rõ ràng là rất quan trọng để dễ dàng bảo trì, mở rộng và kiểm thử. Hai mô hình phổ biến trong phát triển ứng dụng là: MVC (Model – View – Controller) MVP (Model – View […]