SQLite trong Android giúp bạn thực hiện lưu trữ và truy xuất dữ liệu nhanh gọn, hệ thống cơ sở dữ liệu quan hệ nhỏ gọn khi không cần cấu hình quản trị, câu lệnh truy vấn có nét tương đồng SQL.
SQLite không cần một máy chủ chạy riêng biệt mà bản thân nó thực hiện lưu trữ và truy xuất dữ liệu trực tiếp trên từng thiết bị.
Tại sao nên sử dụng SQLite:
- SQLite là một hệ cơ sở dữ liệu mã nguồn mở, được tích hợp mặc định trên thiết bị Android.
- SQLite hỗ trợ cở sở dữ liệu quan hệ.
- SQLite không cần phải yêu cầu thiết lập cấu hình, cài đặt máy chủ. Hỗ trợ cú pháp lưu trữ và truy vấn cơ sở dữ liệu như SQL thế nên dễ dàng sử dụng.
Ví dụ sử dụng SQLite trong Android:
Sau đây là một ví dụ nhỏ xây dựng ứng dụng giúp bạn lưu trữ thông tin danh bạ với việc sử dụng lưu trữ và truy xuất dữ liệu với SQLite trong Android.
Bước 1: Đầu tiên chúng ta cần tạo lớp Person.java chứa thông tin người dùng như id, name, email
package com.teamvietdev.android.sqlitedatabase.model; public class Person { private long id; private String name; private String email; public long getId() { return id; } public void setId(long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } }
Sau đó bạn tạo lớp DatabaseHelper và kế thừa lớp SQLiteOpenHelper và ghi đè 2 phương thức onCreate() và onUpgrade() như sau:
package com.teamvietdev.android.sqlitedatabase.database; import android.content.ContentValues; import android.content.Context; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; import java.util.ArrayList; import java.util.List; public class DatabaseHelper extends SQLiteOpenHelper { private static final int DATABASE_VERSION = 1; private static final String DATABASE_NAME = "dbname"; private static final String TABLE_NAME = "tbperson"; private static final String COLUMN_ID = "id"; private static final String COLUMN_NAME = "name"; private static final String COLUMN_MAIL = "email"; public DatabaseHelper(Context context) { super(context, DATABASE_NAME, null, DATABASE_VERSION); } @Override public void onCreate(SQLiteDatabase db) { String value = String.format("CREATE TABLE %s(%s INTEGER PRIMARY KEY, %s TEXT, %s TEXT)", TABLE_NAME, COLUMN_ID, COLUMN_NAME, COLUMN_MAIL); db.execSQL(value); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { String value = String.format("DROP TABLE IF EXISTS %s", TABLE_NAME); db.execSQL(value); onCreate(db); } }
onCreate() được gọi một lần khi ứng dụng được cài đặt, nó sẽ thực hiện các lệnh để tạo các bảng cần thiết.
onUpgrade() được gọi khi bạn cần cập nhật cơ sở dữ liệu bằng cách sửa đổi thuộc tính DATABASE_VERSION để thực hiện thay đổi.
Lớp SQLiteDatabase là lớp cơ bản dùng để xử lý với SQLite trong Android thực hiện các thao tác CRUD (thêm, sửa, xóa, đọc dữ liệu) vậy chúng ta sẽ áp dụng thực hiện các câu truy vấn.
Lệnh thêm dữ liệu mới vào bảng:
public long create(String name, String mail) { SQLiteDatabase db = this.getWritableDatabase(); ContentValues values = new ContentValues(); values.put(COLUMN_NAME, name); values.put(COLUMN_MAIL, mail); long id = db.insert(TABLE_NAME, null, values); db.close(); return id; }
Lệnh sửa dữ liệu mới vào bảng:
public int update(long id, String name, String mail) { SQLiteDatabase db = this.getWritableDatabase(); ContentValues values = new ContentValues(); values.put(COLUMN_NAME, name); values.put(COLUMN_MAIL, mail); return db.update(TABLE_NAME, values, COLUMN_ID + " = ?", new String[]{String.valueOf(id)}); }
Lệnh xóa dữ liệu mới vào bảng:
public void delete(long id) { SQLiteDatabase db = this.getWritableDatabase(); db.delete(TABLE_NAME, COLUMN_ID + " = ?", new String[]{String.valueOf(id)}); db.close(); }
Lệnh truy xuất dữ liệu lấy thông tin một bản ghi:
public Person getValue(long id) { SQLiteDatabase db = this.getReadableDatabase(); Cursor cursor = db.query(TABLE_NAME, new String[]{COLUMN_ID, COLUMN_NAME, COLUMN_MAIL}, COLUMN_ID + "=?", new String[]{String.valueOf(id)}, null, null, null, null); if (cursor != null) cursor.moveToFirst(); Person person = new Person(); person.setId(cursor.getInt(cursor.getColumnIndex(COLUMN_ID))); person.setName(cursor.getString(cursor.getColumnIndex(COLUMN_NAME))); person.setEmail(cursor.getString(cursor.getColumnIndex(COLUMN_MAIL))); cursor.close(); return person; }
Lệnh truy xuất dữ liệu lấy thông tin danh sách bản ghi:
public List<Person> getAll() { List<Person> list = new ArrayList<>(); String selectQuery = "SELECT * FROM " + TABLE_NAME; SQLiteDatabase db = this.getWritableDatabase(); Cursor cursor = db.rawQuery(selectQuery, null); if (cursor.moveToFirst()) { do { Person person = new Person(); person.setId(cursor.getInt(cursor.getColumnIndex(COLUMN_ID))); person.setName(cursor.getString(cursor.getColumnIndex(COLUMN_NAME))); person.setEmail(cursor.getString(cursor.getColumnIndex(COLUMN_MAIL))); list.add(person); } while (cursor.moveToNext()); } db.close(); return list; }
Sau khi thêm tất cả các phương thức thì bây giờ lớp DatabaseHelper.java sẽ như sau:
package com.teamvietdev.android.sqlitedatabase.database; import android.content.ContentValues; import android.content.Context; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; import com.teamvietdev.android.sqlitedatabase.model.Person; import java.util.ArrayList; import java.util.List; public class DatabaseHelper extends SQLiteOpenHelper { private static final int DATABASE_VERSION = 1; private static final String DATABASE_NAME = "dbname"; private static final String TABLE_NAME = "tbperson"; private static final String COLUMN_ID = "id"; private static final String COLUMN_NAME = "name"; private static final String COLUMN_MAIL = "email"; public DatabaseHelper(Context context) { super(context, DATABASE_NAME, null, DATABASE_VERSION); } @Override public void onCreate(SQLiteDatabase db) { String value = String.format("CREATE TABLE %s(%s INTEGER PRIMARY KEY, %s TEXT, %s TEXT)", TABLE_NAME, COLUMN_ID, COLUMN_NAME, COLUMN_MAIL); db.execSQL(value); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { String value = String.format("DROP TABLE IF EXISTS %s", TABLE_NAME); db.execSQL(value); onCreate(db); } public long create(String name, String mail) { SQLiteDatabase db = this.getWritableDatabase(); ContentValues values = new ContentValues(); values.put(COLUMN_NAME, name); values.put(COLUMN_MAIL, mail); long id = db.insert(TABLE_NAME, null, values); db.close(); return id; } public int update(long id, String name, String mail) { SQLiteDatabase db = this.getWritableDatabase(); ContentValues values = new ContentValues(); values.put(COLUMN_NAME, name); values.put(COLUMN_MAIL, mail); return db.update(TABLE_NAME, values, COLUMN_ID + " = ?", new String[]{String.valueOf(id)}); } public void delete(long id) { SQLiteDatabase db = this.getWritableDatabase(); db.delete(TABLE_NAME, COLUMN_ID + " = ?", new String[]{String.valueOf(id)}); db.close(); } public Person getValue(long id) { SQLiteDatabase db = this.getReadableDatabase(); Cursor cursor = db.query(TABLE_NAME, new String[]{COLUMN_ID, COLUMN_NAME, COLUMN_MAIL}, COLUMN_ID + "=?", new String[]{String.valueOf(id)}, null, null, null, null); if (cursor != null) cursor.moveToFirst(); Person person = new Person(); person.setId(cursor.getInt(cursor.getColumnIndex(COLUMN_ID))); person.setName(cursor.getString(cursor.getColumnIndex(COLUMN_NAME))); person.setEmail(cursor.getString(cursor.getColumnIndex(COLUMN_MAIL))); cursor.close(); return person; } public List<Person> getAll() { List<Person> list = new ArrayList<>(); String selectQuery = "SELECT * FROM " + TABLE_NAME; SQLiteDatabase db = this.getWritableDatabase(); Cursor cursor = db.rawQuery(selectQuery, null); if (cursor.moveToFirst()) { do { Person person = new Person(); person.setId(cursor.getInt(cursor.getColumnIndex(COLUMN_ID))); person.setName(cursor.getString(cursor.getColumnIndex(COLUMN_NAME))); person.setEmail(cursor.getString(cursor.getColumnIndex(COLUMN_MAIL))); list.add(person); } while (cursor.moveToNext()); } db.close(); return list; } }
Bước 2: Bây giờ chúng ta sẽ thiết kế các giao diện màn hình hiển thị, tạo tập tin xml mới có tên là layout_item.xml nhằm thiết kế giao diện hiển thị thông tin tài khoản.
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical" android:layout_margin="5dp"> <TextView android:id="@+id/tvName" android:layout_width="match_parent" android:layout_height="30dp" android:gravity="center_vertical" android:textStyle="bold" android:textSize="20dp" android:text="Team Việt Dev" /> <TextView android:id="@+id/tvMail" android:layout_width="match_parent" android:layout_height="wrap_content" android:textSize="17dp" android:text="teamvietdev@gmail.com" /> </LinearLayout>
Mình sẽ sử dụng RecyclerView để hiển thị dữ liệu danh sách, bạn tạo lớp PersonAdapter.java như sau:
package com.teamvietdev.android.sqlitedatabase.adapter; import android.content.Context; import android.support.v7.widget.RecyclerView; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.TextView; import com.teamvietdev.android.sqlitedatabase.R; import com.teamvietdev.android.sqlitedatabase.model.Person; import java.util.List; public class PersonAdapter extends RecyclerView.Adapter<PersonAdapter.MyViewHolder> { private Context context; private List<Person> listPerson; public PersonAdapter(Context context, List<Person> listPerson) { this.context = context; this.listPerson = listPerson; } @Override public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { View itemView = LayoutInflater.from(parent.getContext()) .inflate(R.layout.layout_item, parent, false); return new MyViewHolder(itemView); } @Override public void onBindViewHolder(MyViewHolder holder, int position) { Person person = listPerson.get(position); holder.tvName.setText(person.getName()); holder.tvMail.setText(person.getEmail()); } @Override public int getItemCount() { return listPerson.size(); } public class MyViewHolder extends RecyclerView.ViewHolder { public TextView tvName; public TextView tvMail; public MyViewHolder(View view) { super(view); tvName = view.findViewById(R.id.tvName); tvMail = view.findViewById(R.id.tvMail); } } }
Trong ứng dụng Android hướng dẫn sử dụng SQLite trong Android thì mình sẽ tạo hộp thoại Dialog để thêm, cập nhật hoặc xóa thông tin tài khoản. Chúng ta sẽ thiết kế giao diện với bạn tạo 2 tập tin dialog_person.xml và dialog_delete.xml như sau:
Tập tin dialog_person.xml:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical"> <TextView android:layout_width="match_parent" android:layout_height="50dp" android:gravity="center" android:background="@color/colorPrimary" android:textColor="#FFFFFF" android:textStyle="bold" android:textSize="18dp" android:text="THÔNG TIN TÀI KHOẢN"/> <EditText android:id="@+id/edtName" android:layout_width="match_parent" android:layout_height="50dp" android:textColor="#000000" android:textSize="17dp" android:hint="Họ và tên"/> <EditText android:id="@+id/edtEmail" android:layout_width="match_parent" android:layout_height="50dp" android:textColor="#000000" android:textSize="17dp" android:hint="Địa chỉ Email.."/> </LinearLayout>
Tập tin dialog_delete.xml:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical"> <TextView android:layout_width="match_parent" android:layout_height="50dp" android:gravity="center" android:background="@color/colorPrimary" android:textColor="#FFFFFF" android:textStyle="bold" android:textSize="18dp" android:text="THÔNG BÁO"/> <TextView android:id="@+id/tvName" android:layout_width="match_parent" android:layout_height="100dp" android:gravity="center" android:textSize="17dp" android:hint="Bạn muốn xóa thông tin người dùng [x] không?"/> </LinearLayout>
Mở tập tin activity_main.xml và thêm RecyclerView nhằm hiển thị danh sách tài khoản.
<?xml version="1.0" encoding="utf-8"?> <android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" xmlns:app="http://schemas.android.com/apk/res-auto" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".view.MainActivity"> <android.support.v7.widget.RecyclerView android:id="@+id/recyclerView" android:layout_width="match_parent" android:layout_height="match_parent"/> <android.support.design.widget.FloatingActionButton android:id="@+id/fab" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="bottom|end" android:layout_margin="@dimen/fab_margin" app:srcCompat="@drawable/ic_add_white_24dp" /> </android.support.design.widget.CoordinatorLayout>
Bước 3: Bây giờ bạn mở tập tin MainActivity.java và xử lý
package com.teamvietdev.android.sqlitedatabase.view; import android.content.DialogInterface; import android.support.design.widget.FloatingActionButton; import android.support.v7.app.AlertDialog; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.support.v7.widget.DefaultItemAnimator; import android.support.v7.widget.LinearLayoutManager; import android.support.v7.widget.RecyclerView; import android.view.LayoutInflater; import android.view.View; import android.widget.EditText; import android.widget.TextView; import com.teamvietdev.android.sqlitedatabase.R; import com.teamvietdev.android.sqlitedatabase.adapter.PersonAdapter; import com.teamvietdev.android.sqlitedatabase.database.DatabaseHelper; import com.teamvietdev.android.sqlitedatabase.listener.DividerItemDecoration; import com.teamvietdev.android.sqlitedatabase.listener.RecyclerTouchListener; import com.teamvietdev.android.sqlitedatabase.model.Person; import java.util.ArrayList; import java.util.List; public class MainActivity extends AppCompatActivity { private RecyclerView recyclerView; private DatabaseHelper db; private List<Person> listPerson; PersonAdapter mAdapter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); recyclerView = findViewById(R.id.recyclerView); db = new DatabaseHelper(this); listPerson = new ArrayList<>(); listPerson = db.getAll(); FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab); fab.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { showPersonDialog(null, -1); } }); mAdapter = new PersonAdapter(this, listPerson); RecyclerView.LayoutManager mLayoutManager = new LinearLayoutManager(getApplicationContext()); recyclerView.setLayoutManager(mLayoutManager); recyclerView.setItemAnimator(new DefaultItemAnimator()); recyclerView.addItemDecoration(new DividerItemDecoration(this, LinearLayoutManager.VERTICAL, 16)); recyclerView.setAdapter(mAdapter); recyclerView.addOnItemTouchListener(new RecyclerTouchListener(this, recyclerView, new RecyclerTouchListener.ClickListener() { @Override public void onClick(View view, final int position) { showPersonDialog(listPerson.get(position), position); } @Override public void onLongClick(View view, int position) { showDeleteDialog(listPerson.get(position), position); } })); } private void create(String name, String mail) { long id = db.create(name, mail); Person person = new Person(); person.setId(id); person.setName(name); person.setEmail(mail); listPerson.add(0, person); mAdapter.notifyDataSetChanged(); } private void update(int position, long id, String name, String mail) { db.update(id, name, mail); Person person = new Person(); person.setId(id); person.setName(name); person.setEmail(mail); listPerson.set(position, person); mAdapter.notifyItemChanged(position); } private void delete(int position, long id) { db.delete(id); listPerson.remove(position); mAdapter.notifyItemRemoved(position); } private void showPersonDialog(final Person person, final int position) { LayoutInflater li = LayoutInflater.from(getApplicationContext()); View promptsView = li.inflate(R.layout.dialog_person, null); final EditText edtName = promptsView.findViewById(R.id.edtName); final EditText edtEmail = promptsView.findViewById(R.id.edtEmail); if (person != null) { edtName.setText(person.getName()); edtEmail.setText(person.getEmail()); } AlertDialog.Builder alertDialogBuilder = new AlertDialog.Builder(this); alertDialogBuilder.setView(promptsView); alertDialogBuilder .setCancelable(true) .setPositiveButton("XÁC NHẬN", new DialogInterface.OnClickListener() { public void onClick(DialogInterface dialog, int id) { if (person == null) { create(edtName.getText().toString(), edtEmail.getText().toString()); } else { update(position, person.getId(), edtName.getText().toString(), edtEmail.getText().toString()); } } }) .setNegativeButton("HỦY BỎ", new DialogInterface.OnClickListener() { public void onClick(DialogInterface dialog, int id) { dialog.cancel(); } }); AlertDialog alertDialog = alertDialogBuilder.create(); alertDialog.setCancelable(false); alertDialog.setCanceledOnTouchOutside(false); alertDialog.show(); } private void showDeleteDialog(final Person person, final int position) { LayoutInflater li = LayoutInflater.from(getApplicationContext()); View promptsView = li.inflate(R.layout.dialog_delete, null); final TextView tvName = promptsView.findViewById(R.id.tvName); tvName.setText("Bạn muốn xóa thông tin người dùng [" + person.getName().toUpperCase() + "] không?"); AlertDialog.Builder alertDialogBuilder = new AlertDialog.Builder(this); alertDialogBuilder.setView(promptsView); alertDialogBuilder .setCancelable(true) .setPositiveButton("XÁC NHẬN", new DialogInterface.OnClickListener() { public void onClick(DialogInterface dialog, int id) { delete(position, person.getId()); } }) .setNegativeButton("HỦY BỎ", new DialogInterface.OnClickListener() { public void onClick(DialogInterface dialog, int id) { dialog.cancel(); } }); AlertDialog alertDialog = alertDialogBuilder.create(); alertDialog.setCancelable(false); alertDialog.setCanceledOnTouchOutside(false); alertDialog.show(); } }
Trong gói listener tạo hai lớp lần lượt RecyclerTouchListener.java và MyDividerItemDecoration.java
Lớp RecyclerTouchListener.java:
package com.teamvietdev.android.sqlitedatabase.listener; import android.content.Context; import android.support.v7.widget.RecyclerView; import android.view.GestureDetector; import android.view.MotionEvent; import android.view.View; public class RecyclerTouchListener implements RecyclerView.OnItemTouchListener { private ClickListener clicklistener; private GestureDetector gestureDetector; public RecyclerTouchListener(Context context, final RecyclerView recycleView, final ClickListener clicklistener) { this.clicklistener = clicklistener; gestureDetector = new GestureDetector(context, new GestureDetector.SimpleOnGestureListener() { @Override public boolean onSingleTapUp(MotionEvent e) { return true; } @Override public void onLongPress(MotionEvent e) { View child = recycleView.findChildViewUnder(e.getX(), e.getY()); if (child != null && clicklistener != null) { clicklistener.onLongClick(child, recycleView.getChildAdapterPosition(child)); } } }); } @Override public boolean onInterceptTouchEvent(RecyclerView rv, MotionEvent e) { View child = rv.findChildViewUnder(e.getX(), e.getY()); if (child != null && clicklistener != null && gestureDetector.onTouchEvent(e)) { clicklistener.onClick(child, rv.getChildAdapterPosition(child)); } return false; } @Override public void onTouchEvent(RecyclerView rv, MotionEvent e) { } @Override public void onRequestDisallowInterceptTouchEvent(boolean disallowIntercept) { } public interface ClickListener { void onClick(View view, int position); void onLongClick(View view, int position); } }
Lớp MyDividerItemDecoration.java:
package com.teamvietdev.android.sqlitedatabase.listener; import android.content.Context; import android.content.res.Resources; import android.content.res.TypedArray; import android.graphics.Canvas; import android.graphics.Rect; import android.graphics.drawable.Drawable; import android.support.v7.widget.LinearLayoutManager; import android.support.v7.widget.RecyclerView; import android.util.TypedValue; import android.view.View; public class DividerItemDecoration extends RecyclerView.ItemDecoration { private static final int[] ATTRS = new int[]{ android.R.attr.listDivider }; public static final int HORIZONTAL_LIST = LinearLayoutManager.HORIZONTAL; public static final int VERTICAL_LIST = LinearLayoutManager.VERTICAL; private Drawable mDivider; private int mOrientation; private Context context; private int margin; public DividerItemDecoration(Context context, int orientation, int margin) { this.context = context; this.margin = margin; final TypedArray a = context.obtainStyledAttributes(ATTRS); mDivider = a.getDrawable(0); a.recycle(); setOrientation(orientation); } public void setOrientation(int orientation) { if (orientation != HORIZONTAL_LIST && orientation != VERTICAL_LIST) { throw new IllegalArgumentException("invalid orientation"); } mOrientation = orientation; } @Override public void onDrawOver(Canvas c, RecyclerView parent, RecyclerView.State state) { if (mOrientation == VERTICAL_LIST) { drawVertical(c, parent); } else { drawHorizontal(c, parent); } } public void drawVertical(Canvas c, RecyclerView parent) { final int left = parent.getPaddingLeft(); final int right = parent.getWidth() - parent.getPaddingRight(); final int childCount = parent.getChildCount(); for (int i = 0; i < childCount; i++) { final View child = parent.getChildAt(i); final RecyclerView.LayoutParams params = (RecyclerView.LayoutParams) child .getLayoutParams(); final int top = child.getBottom() + params.bottomMargin; final int bottom = top + mDivider.getIntrinsicHeight(); mDivider.setBounds(left + dpToPx(margin), top, right - dpToPx(margin), bottom); mDivider.draw(c); } } public void drawHorizontal(Canvas c, RecyclerView parent) { final int top = parent.getPaddingTop(); final int bottom = parent.getHeight() - parent.getPaddingBottom(); final int childCount = parent.getChildCount(); for (int i = 0; i < childCount; i++) { final View child = parent.getChildAt(i); final RecyclerView.LayoutParams params = (RecyclerView.LayoutParams) child .getLayoutParams(); final int left = child.getRight() + params.rightMargin; final int right = left + mDivider.getIntrinsicHeight(); mDivider.setBounds(left, top + dpToPx(margin), right, bottom - dpToPx(margin)); mDivider.draw(c); } } @Override public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) { if (mOrientation == VERTICAL_LIST) { outRect.set(0, 0, 0, mDivider.getIntrinsicHeight()); } else { outRect.set(0, 0, mDivider.getIntrinsicWidth(), 0); } } private int dpToPx(int dp) { Resources r = context.getResources(); return Math.round(TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, dp, r.getDisplayMetrics())); } }
Cuối cùng khi đã hoàn thành xong các bước trên bạn hãy tiến hành chạy thử chương trình ví dụ sử dụng SQLite trong Android, còn đây là kết quả mà mình thực hiện:
Lời kết: Như vậy trong ứng dụng Android để thực hiện việc lưu trữ và truy xuất dữ liệu bạn có thể sử dụng SQLite trong Android. Ngoài ra bạn có thể xem thêm nhiều bài viết khác trong chủ đề lập trình Android tại Team Việt Dev.
(Tác giả: Team Việt Dev)