Dasar SQLlite,Membuat button save,cari,edit,dan
delet
Pertama
buatlah project baru
Nama Aplikasi : Note PIN
Project Name :scrool
Package Name : com.taufik
Activity name : MainActivity
Layout Name : activity_main
1).Isikan code di pawah ini pada string.xml
yang berada pada Folder “res>menu”.
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="hello">Masukkan Nama dan PIN</string>
<string name="app_name">NotePIN</string>
<string name="btnAddtxt">Save</string>
<string name="namaLabel">Nama</string>
<string name="hobiLabel">PIN BB</string>
<string name="nomorLabel">No.</string>
<string name="btnGetRow">Cari</string>
<string name="btnUpdateRow">Update</string>
<string name="ketUpdate">Sebelum mengubah data,pilih dulu baris ke berapa data yang
akan diubah</string>
<string name="ketAmbilBaris">Tulis No Urut</string>
<string name="ketDelete">Tulis No Urut</string>
<string name="btnDel">Delete</string>
</resources>
2.Isikan code dibawah ini pada activiry_maim.xml
yang berada di folder “res>layout”
<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:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity"
>
<ScrollView
android:id="@+id/scrollView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
>
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/hello"
/>
<LinearLayout
android:id="@+id/linearLayout1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
>
<EditText
android:id="@+id/inNama"
android:layout_width="118dp"
android:layout_height="wrap_content"
android:ems="10"
/>
<requestFocus />
<EditText
android:id="@+id/inHobi"
android:layout_width="91dp"
android:layout_height="wrap_content"
android:layout_weight="1.47"
android:ems="10"
>
</EditText>
<Button
android:id="@+id/btnAdd"
android:layout_width="80dp"
android:layout_height="wrap_content"
android:layout_weight="0.33"
android:text="Save"
/>
</LinearLayout>
<View
android:id="@+id/view2"
android:layout_width="wrap_content"
android:layout_height="1dip"
android:background="#FF909090"
>
</View>
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/ketUpdate"
>
</TextView>
<View
android:id="@+id/view2"
android:layout_width="wrap_content"
android:layout_height="1dip"
android:background="#FF909090"
>
</View>
<LinearLayout
android:id="@+id/linearLayout2"
android:layout_width="match_parent"
android:layout_height="wrap_content"
>
<TextView
android:id="@+id/textView2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/ketAmbilBaris"
>
</TextView>
<EditText
android:id="@+id/inGetId"
android:layout_width="48dp"
android:layout_height="wrap_content"
>
</EditText>
<Button
android:id="@+id/btnGetId"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Cari"
>
</Button>
</LinearLayout>
<LinearLayout
android:id="@+id/linearLayout3"
android:layout_width="match_parent"
android:layout_height="wrap_content"
>
<EditText
android:id="@+id/inUpdateNama"
android:layout_width="100dip"
android:layout_height="wrap_content"
android:layout_weight="1.16"
>
</EditText>
<EditText
android:id="@+id/inUpdateHobi"
android:layout_width="100dip"
android:layout_height="wrap_content"
android:layout_weight="1.65"
>
</EditText>
<Button
android:id="@+id/btnUpdate"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="0.23"
android:text="Update"
>
</Button>
</LinearLayout>
<View
android:id="@+id/view2"
android:layout_width="wrap_content"
android:layout_height="1dip"
android:background="#FF909090"
>
</View>
<LinearLayout
android:id="@+id/linearLayout4"
android:layout_width="match_parent"
android:layout_height="wrap_content"
>
<TextView
android:id="@+id/textView3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Delete"
/>
<EditText
android:id="@+id/idDelete"
android:layout_width="47dp"
android:layout_height="wrap_content"
/>
<Button
android:id="@+id/button1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Delete"
/>
</LinearLayout>
<View
android:id="@+id/view2"
android:layout_width="wrap_content"
android:layout_height="1dip"
android:background="#FF909090"
>
</View>
<TableLayout
android:id="@+id/tabel_data"
android:layout_width="match_parent"
android:layout_height="wrap_content"
>
<TableRow
android:id="@+id/tableRow1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
>
<TextView
android:id="@+id/no_id"
android:layout_width="50dip"
android:layout_height="wrap_content"
android:text="@string/nomorLabel" >
</TextView>
<TextView
android:id="@+id/nama_id"
android:layout_width="100dip"
android:layout_height="wrap_content"
android:text="@string/namaLabel" >
</TextView>
<TextView
android:id="@+id/hobi_id"
android:layout_width="100dip"
android:layout_height="wrap_content"
android:text="@string/hobiLabel" >
</TextView>
</TableRow>
</TableLayout>
</LinearLayout>
</ScrollView>
</RelativeLayout>
3).Isikan code dibawah ini pada MainActivity.java
yang berada di folder “src”
package
com.taufik;
import
java.util.ArrayList;
import
android.app.Activity;
import
android.os.Bundle;
import
android.util.Log;
import
android.view.View;
import
android.widget.Button;
import
android.widget.EditText;
import
android.widget.TableLayout;
import
android.widget.TableRow;
import
android.widget.TextView;
import
android.widget.Toast;
public class MainActivity
extends Activity {
DatabaseManager dm;
EditText nama, hobi, GetId, updateNama, updateHobi, idDel;
Button addBtn, getIdBtn, updateBtn, delBtn;
TableLayout tabel4data;
// tabel for
data
/** Called when the
activity is first created. */
@Override
public void
onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
dm = new
DatabaseManager(this);
setupView();
fungsiBtn();
updateTable();
}
public void
setupView() {
tabel4data =
(TableLayout) findViewById(R.id.tabel_data);
nama =
(EditText) findViewById(R.id.inNama);
hobi =
(EditText) findViewById(R.id.inHobi);
updateNama =
(EditText) findViewById(R.id.inUpdateNama);
updateHobi =
(EditText) findViewById(R.id.inUpdateHobi);
GetId =
(EditText) findViewById(R.id.inGetId);
idDel=(EditText)findViewById(R.id.idDelete);
addBtn =
(Button) findViewById(R.id.btnAdd);
getIdBtn =
(Button) findViewById(R.id.btnGetId);
updateBtn =
(Button) findViewById(R.id.btnUpdate);
delBtn =
(Button) findViewById(R.id.button1);
}
public void
fungsiBtn() {
addBtn.setOnClickListener(new
View.OnClickListener() {
@Override
public void
onClick(View v) {
simpKamuta();
kosongkanField();
}
});
getIdBtn.setOnClickListener(new
View.OnClickListener() {
@Override
public void
onClick(View b) {
ambilBaris();
}
});
updateBtn.setOnClickListener(new
View.OnClickListener() {
@Override
public void
onClick(View c) {
updateBaris();
kosongkanField();
}
});
delBtn.setOnClickListener(new
View.OnClickListener() {
@Override
public void
onClick(View d) {
//
TODO Auto-generated method stub
deleteData();
kosongkanField();
}
});
}
protected void
kosongkanField() {
nama.setText("");
hobi.setText("");
updateNama.setText("");
updateHobi.setText("");
GetId.setText("");
idDel.setText("");
}
private void
deleteData() {
dm.deleteBaris(Long.parseLong(idDel.getText().toString()));
updateTable();
}
protected void
updateBaris() {
dm.updateBaris(Long.parseLong(GetId.getText().toString()),
updateNama
.getText().toString(),
updateHobi.getText().toString());
updateTable();
}
private void
ambilBaris() {
try {
ArrayList<Object>
baris;
baris
= dm.ambilBaris(Long.parseLong(GetId.getText().toString()));
updateNama.setText((String)
baris.get(1));
updateHobi.setText((String)
baris.get(2));
} catch
(NumberFormatException e) {
e.printStackTrace();
Log.e("eror
db", e.toString());
Toast.makeText(getBaseContext(),
e.toString(), Toast.LENGTH_LONG)
.show();
}
}
protected void
simpKamuta() {
try {
dm.addRow(nama.getText().toString(),
hobi.getText().toString());
updateTable();
} catch
(Exception e) {
e.printStackTrace();
Toast.makeText(getBaseContext(),
"gagal simpan," + e.toString(),
Toast.LENGTH_LONG).show();
}
}
protected void
updateTable() {
while (tabel4data.getChildCount()
> 1) {
tabel4data.removeViewAt(1);
}
ArrayList<ArrayList<Object>>
data = dm.ambilSemuaBaris();
//
for (int
posisi = 0; posisi < data.size();
posisi++) {
TableRow
tabelBaris = new TableRow(this);
ArrayList<Object>
baris = data.get(posisi);
TextView
idTxt = new TextView(this);
idTxt.setText(baris.get(0).toString());
tabelBaris.addView(idTxt);
TextView
namaTxt = new TextView(this);
namaTxt.setText(baris.get(1).toString());
tabelBaris.addView(namaTxt);
TextView
hobiTxt = new TextView(this);
hobiTxt.setText(baris.get(2).toString());
tabelBaris.addView(hobiTxt);
tabel4data.addView(tabelBaris);
}
}
}
4.Kemudin
buat class baru dengan nama DatabaseManager.java,dan isiskan code di bawah ini
package
com.taufik;
import java.util.ArrayList;
import
android.content.ContentValues;
import
android.content.Context;
import
android.database.Cursor;
import
android.database.sqlite.SQLiteDatabase;
import
android.database.sqlite.SQLiteOpenHelper;
import
android.util.Log;
import
android.widget.Toast;
public class
DatabaseManager {
private static final
String ROW_ID = "_id";
private static final
String ROW_NAMA = "nama";
private static final
String ROW_HOBI = "hobi";
private static final
String NAMA_DB = "DatabaseAndroidDua";
private static final
String NAMA_TABEL = "hobiku ";
private static final int DB_VERSION =
1;
private static final
String CREATE_TABLE = "create table " + NAMA_TABEL
+
" (" + ROW_ID + "
integer PRIMARY KEY autoincrement," + ROW_NAMA
+
" text," + ROW_HOBI + "
text)";
private final
Context context;
private
DatabaseOpenHelper dbHelper;
private
SQLiteDatabase db;
public
DatabaseManager(Context ctx) {
this.context =
ctx;
dbHelper = new
DatabaseOpenHelper(ctx);
db = dbHelper.getWritableDatabase();
}
private static class
DatabaseOpenHelper extends SQLiteOpenHelper {
public
DatabaseOpenHelper(Context context) {
super(context,
NAMA_DB, null, DB_VERSION);
}
@Override
public void
onCreate(SQLiteDatabase db) {
db.execSQL(CREATE_TABLE);
}
@Override
public void
onUpgrade(SQLiteDatabase db, int
oldVer, int newVer) {
db.execSQL("DROP
TABLE IF EXISTS " + NAMA_DB);
onCreate(db);
}
}
public void
close() {
dbHelper.close();
}
public void
addRow(String nama, String hobi) {
ContentValues
values = new ContentValues();
values.put(ROW_NAMA,
nama);
values.put(ROW_HOBI,
hobi);
try {
db.insert(NAMA_TABEL, null,
values);
} catch
(Exception e) {
Log.e("DB
ERROR", e.toString());
e.printStackTrace();
}
}
public
ArrayList<ArrayList<Object>> ambilSemuaBaris() {
ArrayList<ArrayList<Object>>
dataArray = new ArrayList<ArrayList<Object>>();
Cursor cur;
try {
cur
= db.query(NAMA_TABEL, new
String[] { ROW_ID, ROW_NAMA,
ROW_HOBI }, null, null, null, null, null);
cur.moveToFirst();
if
(!cur.isAfterLast()) {
do {
ArrayList<Object>
dataList = new ArrayList<Object>();
dataList.add(cur.getLong(0));
dataList.add(cur.getString(1));
dataList.add(cur.getString(2));
dataArray.add(dataList);
}
while (cur.moveToNext());
}
} catch
(Exception e) {
e.printStackTrace();
Log.e("DEBE
ERROR", e.toString());
Toast.makeText(context, "gagal
ambil semua baris:" + e.toString(),
Toast.LENGTH_SHORT).show();
}
return
dataArray;
}
public
ArrayList<Object> ambilBaris(long
rowId) {
ArrayList<Object>
arrbaris = new ArrayList<Object>();
Cursor cursor;
try {
cursor
= db.query(NAMA_TABEL, new
String[] { ROW_ID, ROW_NAMA,
ROW_HOBI }, ROW_ID + "=" +
rowId, null, null, null, null,
null);
cursor.moveToFirst();
if
(!cursor.isAfterLast()) {
do {
arrbaris.add(cursor.getLong(0));
arrbaris.add(cursor.getString(1));
arrbaris.add(cursor.getString(2));
} while
(cursor.moveToNext());
String
r = String.valueOf(arrbaris);
Toast.makeText(context, "haha" +
r, Toast.LENGTH_SHORT).show();
}
cursor.close();
} catch
(Exception e) {
e.printStackTrace();
Log.e("error",
e.toString());
Toast.makeText(context, "hhii" +
e.toString(), Toast.LENGTH_SHORT)
.show();
}
return
arrbaris;
}
public void
updateBaris(long rowId, String nama, String hobi) {
ContentValues cv
= new ContentValues();
cv.put(ROW_NAMA,
nama);
cv.put(ROW_HOBI,
hobi);
try {
db.update(NAMA_TABEL,
cv, ROW_ID + "=" + rowId, null);
} catch
(Exception e) {
e.printStackTrace();
Log.e("Db
Error", e.toString());
}
}
public void
deleteBaris(long idBaris) {
try {
db.delete(NAMA_TABEL, ROW_ID + "=" +
idBaris, null);
} catch
(Exception e) {
e.printStackTrace();
Log.e("Error",
e.toString());
}
}
}
5). Dan
Run lah ,,taraaa lihat hasilnya akan seperti ini