
บทเรียนเบื้องต้นสำหรับผู้พัฒนาแอพพลิเคชัน Android กับการใช้งาน SQLite ร่วมกับ Delte SQL เพื่อลบข้อมูลในตารางฐานข้อมูล SQLite แบบง่ายผ่านหน้า Intent Activity
ศึกษาบทเรียนก่อนหน้าก่อนจะได้เข้าใจครับ ที่นี่
- เขียนแอพ Android การเชื่อมต่อ SQLite กับ ListView เบื้องต้น
- เขียนแอพ Android การเชื่อมต่อ SQLite กับการ Insert ข้อมูล
ขั้นตอนเดิมๆ ครับสร้าง Blank Activity มาใหม่ตั้งชื่อว่า MainActivity3.java และ activity_main3.xml

ออกแบบหน้าจอ activity_main3.xml ดังนี้

ไฟล์ xml จะได้ดังนี้
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingBottom="@dimen/activity_vertical_margin"
tools:context="daydev.com.sqlitetut.MainActivity3">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textAppearance="?android:attr/textAppearanceLarge"
android:text="DELETE DATA"
android:id="@+id/textView2"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:layout_marginTop="45dp" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textAppearance="?android:attr/textAppearanceLarge"
android:text="Large Text"
android:id="@+id/txtTitleName"
android:layout_marginTop="47dp"
android:width="300dp"
android:textColor="#ffffe53b"
android:layout_below="@+id/textView2"
android:layout_centerHorizontal="true" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Delete"
android:id="@+id/delButton"
android:layout_marginTop="37dp"
android:width="300dp"
android:layout_below="@+id/txtTitleName"
android:layout_centerHorizontal="true"
android:background="#ffff1d00" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Back To Home"
android:id="@+id/backtohome"
android:width="300dp"
android:layout_below="@+id/delButton"
android:layout_alignStart="@+id/delButton"
android:layout_marginTop="79dp" />
</RelativeLayout>
ต่อมาไปที่ MainActivity.java เพิ่มส่วนของการแตะที่ ListView ตำแหน่ง Rows ให้เปลี่ยนหน้าไป MainActivity3.java พร้อมส่ง Parameter ชื่อเรื่องไปด้วยผ่าน Intent
listViewMovies.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
int itemPosition = position;
String itemValue = (String)listViewMovies.getItemAtPosition(position);
Intent showPage = new Intent(MainActivity.this,MainActivity3.class);
showPage.putExtra("title",""+itemValue+"");
startActivity(showPage);
}
});
เปิดไฟล์ MainActivity3.java ขึ้นมาประกาศ Header ให้พร้อมตามนี้
import android.content.ContentValues; import android.content.Intent; import android.database.sqlite.SQLiteDatabase; import android.support.v7.app.ActionBarActivity; import android.os.Bundle; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.widget.Button; import android.widget.TextView; import android.widget.Toast;
ส่วนของการรับค่า Parameter ผ่าน Intent มาแสดงผล
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main3);
this.setTitle("View and Delete data");
final TextView txtTitle_show = (TextView)findViewById(R.id.txtTitleName);
Intent intent= getIntent();
final String txt_get_title = intent.getStringExtra("title");
txtTitle_show.setText(txt_get_title);
Button backHome = (Button)findViewById(R.id.backtohome);
backHome.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent showPage = new Intent(MainActivity3.this,MainActivity.class);
startActivity(showPage);
}
});
Button deleteData = (Button)findViewById(R.id.delButton);
deleteData.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
DeleteRow(txt_get_title);
}
});
}
ประกาศตัวแปร Public ด้วยนะครับ
public class MainActivity3 extends ActionBarActivity {
SQLiteDatabase sqliteMyDB;
MyDbHelper myDataHelper;
ปุ่ม Delete มีฟังก์ชันดังนี้ เมื่อกดแล้วไปเรียกฟังก์ชัน DeleteRow(txt_get_title); มีการส่ง txt_get_title ไปเป็นตัวแปร
Button deleteData = (Button)findViewById(R.id.delButton);
deleteData.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
DeleteRow(txt_get_title);
}
});
เพิ่ม Public long ขึ้นมาใหม่ชื่อว่า DeleteRow() ใส่ code ดังนี้
public long DeleteRow(String dataTitle){
try {
myDataHelper = new MyDbHelper(this);
ContentValues Val = new ContentValues();
sqliteMyDB = myDataHelper.getWritableDatabase();
long rows = sqliteMyDB.delete(myDataHelper.TABLE_NAME,"title=?",new String[] { String.valueOf(dataTitle) });
sqliteMyDB.close();
Toast.makeText(MainActivity3.this, "Success!", Toast.LENGTH_SHORT).show();
return rows;
} catch (Exception e) {
return -1;
}
}
คำสั่งในการ ลบหลักๆ คือ WHERE เทียบกับ title=”” ในส่วนนี้
long rows = sqliteMyDB.delete(myDataHelper.TABLE_NAME,"title=?",new String[] { String.valueOf(dataTitle) });
ภาพรวม code ทั้งหมดของ MainActivity3.java
package daydev.com.sqlitetut;
import android.content.ContentValues;
import android.content.Intent;
import android.database.sqlite.SQLiteDatabase;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;
public class MainActivity3 extends ActionBarActivity {
SQLiteDatabase sqliteMyDB;
MyDbHelper myDataHelper;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main3);
this.setTitle("View and Delete data");
final TextView txtTitle_show = (TextView)findViewById(R.id.txtTitleName);
Intent intent= getIntent();
final String txt_get_title = intent.getStringExtra("title");
txtTitle_show.setText(txt_get_title);
Button backHome = (Button)findViewById(R.id.backtohome);
backHome.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent showPage = new Intent(MainActivity3.this,MainActivity.class);
startActivity(showPage);
}
});
Button deleteData = (Button)findViewById(R.id.delButton);
deleteData.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
DeleteRow(txt_get_title);
}
});
}
public long DeleteRow(String dataTitle){
try {
myDataHelper = new MyDbHelper(this);
ContentValues Val = new ContentValues();
sqliteMyDB = myDataHelper.getWritableDatabase();
long rows = sqliteMyDB.delete(myDataHelper.TABLE_NAME,"title=?",new String[] { String.valueOf(dataTitle) });
sqliteMyDB.close();
Toast.makeText(MainActivity3.this, "Success!", Toast.LENGTH_SHORT).show();
return rows;
} catch (Exception e) {
return -1;
}
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu_main_activity3, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
//noinspection SimplifiableIfStatement
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
}
ทดสอบลอง Run ตัวแอพพลิเคชันของเราครับ แตะที่ 500 Days of Summer
กด Delete ซะ แล้วกลับไปหน้าแรก
ข้อมูลแถวใหม่ที่เพิ่งเพิ่มเข้าไปหายไปแล้ว
ศึกษาบทเรียนเก่าๆ ได้ที่ https://www.daydev.com/category/developer/android-developer







