Kali ini kita akan membahas penggunaan fitur database android.
Kalau kita baca spesifikasi OS android ini, maka salah satu fitur
yang ditawarkan adalah kita dapat membuat database di android yaitu
dengan menggunakan SQLite. Jadi kita bisa membuat
aplikasi seperti yang ada di computer walaupun tidak persis sama karena
computer memiliki resource yang lebih besar.
Dulu waktu belajar J2ME kita jika ingin menyimpan data diaplikasi kita, kita menggunakan Recors Store (RMS). Dimana dalam inserting data dan query data membutuhkan effort coding yang lumayan
Agar semangat belajarnya, dalam mempelajari sesuatu hendaknya kita
selalu bertanya dalam diri, kalau dalam hal ini pertanyaan yang harus
diajukan adalah :
1. Untuk apasih belajar penggunaan database di android?
Kalau yang ini simple jawabnya, yah supaya bisa membuat aplikasi yang memnafaatkan fungsi database diandroid
2. Kalau sudah menguasai, apa manfaatnya buat saya ?
Dengan database kita bisa membuat banyak aplikasi yang bermanfaat. Seperti.
- Point Of Sales (POS) bahasa indonesianya aplikasi penjualan.
Kita bisa menyimpan data product yang kita jual dan transaksi
penjualannya. Dengan adanya data kita bisa membuat report penjualannya
bisa dalam bentuk table, list, bisa graphic (chart) juga lho.
- Aplikasi buat pendukung bisnis Cuci Mobil / Motor
Pernah cuci motor atau mobilkan, nah lihat pas kita bayar, kasirnya
nyatatnya pakai buku atau pakai computer kalau pakai computer lihat
masih pakai excel atau sudah aplikasi. Nah kalau masih pakai buku atau
excel ada peuang tuh, kita tawarkan aplikasi android untuk mencatat
pendapatan.
- Kalau 2 contoh diatas kurang
keren, berarti anda butuh tantangan lebih, buatlah apalikasi mobile yang
merupakan client dari sebuah server. Kalau jaringan internet ada dan
lancar tentu ini mudah saja, nah sekarang kita dituntut untuk develop
aplikasi yang mampu mengatasi hal ini, artinya dalam kondisi internet
matipun aplikasi masih dapat digunakan dan nanti setelah internetnya
hidup data transaksi offline tadi akan dikirim ke server. Nah untuk
mewujudkan itu kita perlu database diaplikasi mobile kita untuk
menyimpan data transaksi yang terjadi pada waktu offline.
- Untuk yang pernah main Game pasti pernah merasa bangga kalau namanya masuk dalam daftar highest score. Nah database dapat kita manfaatkan untuk menyimpan daftar tersebut.
Banyakkan manfaatnya, kalau gitu sekarang semangatnya tambah 10 kali lipat hehehe
Bahan bakar semangat telah ditambah sekarang waktunya action.
SQLite
Seperti telah dijelaskan diatas database pada android menggunakan SQLite. Dengan SQLite untuk insert, update dan query data dapat dilakukan dengan syntak SQL.
Untuk itu sebelum melangkah pembuatan aplikasi Android yang
memanfatkan firtur SQlite databasenya, kita harus menguasai cara
menggunakan SQLite.
Sama seperti database lainnya syntak SQLnya terbagi 2 kategori yaitu
syntak untuk Data Definition Language (DDL) dan Data Manipulation
Language (DML). Bagi yang pernah belajar database pasti tidak asing
dengan kedua istilah tersebut.
Sekarang ada pertanyaan nih apa beda DDL dan DML ?
Biar mudah dipahami, kalau database itu kita ibaratkan sebuah rumah, maka DDL itu adalah syntax untuk membuat rumah, menambah kamar, merubah bangunan rumah, makanya yang termasuk syntak-syantak DDL adalah create table, alter table, drop table.
sedangkan DML adalah syntax untuk mengetahui isi rumah, siapa saja penghuninya, berapa jumlahnya, ada berapa yang pria dan yang wanita, adakah anak-anak dirumah itu.
Makanya yang termasuk syntak-syntak DML adalah insert, update, delete, select
Sekarang mari kita buat project yang menggunakan database sqlite di
android. Dulu sebelum pakai android dihandphone yang dulu pasati pernah
install kamus inggris Indonesia, yang kita gunakan untuk mencari
terjemahan suatu kata dalam bahasa inggris ke bahasa Indonesia.
Sebetulnya diandroid juga sudah ada yang buat. Tetapi tentunya akan
lebih puas jika kita buat sendiri.
Mari kita mulai langkah-langkahnya
1. Buat New Project dengan nama Kamus, lengkapi seperti gambar dibawah
2. Setelah project tercreate maka secara otomatis android membentuk 3 file yaitu :
· main.xml
· string.xml
· showKamus.java
3. untuk membuat user interfacenya, bukafile main.xml lalu ketikkan kode berikut
01 | <? xml version = "1.0" encoding = "utf-8" ?> |
03 | android:orientation = "vertical" android:layout_width = "fill_parent" |
04 | android:layout_height = "fill_parent" > |
06 | < TextView android:layout_width = "fill_parent" |
07 | android:layout_height = "wrap_content" android:text = "Kamus Inggris Indonesia" /> |
08 | < TextView android:text = "Inggris :" android:id = "@+id/TextView01" |
09 | android:layout_width = "wrap_content" android:layout_height = "wrap_content" ></ TextView > |
10 | < EditText android:text = "" android:id = "@+id/txtInggris" |
11 | android:layout_width = "fill_parent" android:layout_height = "wrap_content" ></ EditText > |
12 | < Button android:text = "Terjemahkan" android:id = "@+id/btnTerjemah" |
13 | android:layout_width = "fill_parent" android:layout_height = "wrap_content" |
14 | android:onClick = "getTerjemahan" ></ Button > |
15 | < TextView android:text = "Indonesia :" android:id = "@+id/TextView03" |
16 | android:layout_width = "wrap_content" android:layout_height = "wrap_content" ></ TextView > |
17 | < EditText android:text = "" android:id = "@+id/txtIndonesia" |
18 | android:layout_width = "fill_parent" android:layout_height = "wrap_content" |
19 | android:editable = "false" ></ EditText > |
Kode diatas akan menghasilkan user interface kamus bahasa inggris
Indonesia yang terdiri dari inputan untuk memasukkan kata bahasa
inggris, tombol yang apabila dilik nantinya akan mencari terjemahan dari
kata bahasa inggris tersebut ke bahasa Indonesia dane menampilkannya.
4. Untuk pembuatan databasenya kita buat class baru yang mengeksten class SQLiteOpenHelper dengan
nama DataKamus.java, kemudian ketikkan kode berikut
03 | import android.content.ContentValues; |
04 | import android.content.Context; |
05 | import android.database.sqlite.SQLiteDatabase; |
06 | import android.database.sqlite.SQLiteOpenHelper; |
08 | public class DataKamus extends SQLiteOpenHelper { |
09 | private static final String DATABASE_NAME = "dbkamus" ; |
10 | public static final String INGGRIS= "inggris" ; |
11 | public static final String INDONESIA = "indonesia" ; |
14 | public DataKamus(Context context) { |
15 | super (context, DATABASE_NAME, null , 1 ); |
19 | public void createTable(SQLiteDatabase db){ |
20 | db.execSQL( "DROP TABLE IF EXISTS kamus" ); |
21 | db.execSQL( "CREATE TABLE if not exists kamus (id INTEGER PRIMARY KEY AUTOINCREMENT, inggris TEXT, indonesia TEXT);" ); |
25 | public void generateData(SQLiteDatabase db){ |
26 | ContentValues cv= new ContentValues(); |
27 | cv.put(INGGRIS, "run" ); |
28 | cv.put(INDONESIA, "lari" ); |
29 | db.insert( "kamus" , INGGRIS, cv); |
30 | cv.put(INGGRIS, "walk" ); |
31 | cv.put(INDONESIA, "jalan" ); |
32 | db.insert( "kamus" , INGGRIS, cv); |
33 | cv.put(INGGRIS, "read" ); |
34 | cv.put(INDONESIA, "membaca" ); |
35 | db.insert( "kamus" , INGGRIS, cv); |
39 | public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { |
44 | public void onCreate(SQLiteDatabase db) { |
Pada class DataKamus, disinilah kita membuat databasenya, membuat table dan mengisikan data pada table
(kode diatas akan menginsertkan 3 record data) tersebut.
5. sekarang mari kita kerjakan otak dari aplikasi kamus ini, buka file showKamus.java,
kemudian ketikkan kode berikut
03 | import android.app.Activity; |
04 | import android.database.Cursor; |
05 | import android.database.sqlite.SQLiteDatabase; |
06 | import android.os.Bundle; |
07 | import android.view.View; |
08 | import android.widget.EditText; |
10 | public class showKamus extends Activity { |
12 | private SQLiteDatabase db = null ; |
13 | private Cursor kamusCursor = null ; |
14 | private EditText txtInggris; |
15 | private EditText txtIndonesia; |
16 | private DataKamus datakamus = null ; |
17 | public static final String INGGRIS = "inggris" ; |
18 | public static final String INDONESIA = "indonesia" ; |
20 | /** Called when the activity is first created. */ |
22 | public void onCreate(Bundle savedInstanceState) { |
23 | super .onCreate(savedInstanceState); |
24 | datakamus = new DataKamus( this ); |
25 | db = datakamus.getWritableDatabase(); |
26 | datakamus.createTable(db); |
27 | datakamus.generateData(db); |
29 | setContentView(R.layout.main); |
30 | txtInggris = (EditText) findViewById(R.id.txtInggris); |
31 | txtIndonesia = (EditText) findViewById(R.id.txtIndonesia); |
35 | public void getTerjemahan(View view) { |
37 | String englishword = txtInggris.getText().toString(); |
38 | kamusCursor = db.rawQuery( "SELECT ID, INGGRIS, INDONESIA " |
39 | + "FROM kamus where INGGRIS='" + englishword |
40 | + "' ORDER BY INGGRIS" , null ); |
42 | if (kamusCursor.moveToFirst()) { |
43 | result = kamusCursor.getString( 2 ); |
44 | for (; !kamusCursor.isAfterLast(); kamusCursor.moveToNext()) { |
45 | result = kamusCursor.getString( 2 ); |
48 | if (result.equals( "" )) { |
49 | result = "Terjemahan Not Found" ; |
51 | txtIndonesia.setText(result); |
56 | public void onDestroy() { |
pada method onCreate, disini kita membuat object datakamus dari class DataKamus dari object
tersebut kita call method datakamus.createTable(db); dan datakamus.generateData(db);
setelah kita call kedua method diatas maka table dan datanya sudah siap
Method getTerjemahan akan dipanggil pada saat kita mengklik tombol Terjemahkan.
Pada Method ini kita tangkap inputan kata bahasa inggrisnya dari object txtInggris
kemudian kita lakukan query ke table kamus dan menampilkan hasilnya pada object txtIndonesia.
6. Mari kita run projectnya, pada inputan Inggris, kita isi dengan run
kemudian klik tombol Terjemahkan
Wow, keren dengan koding yang singkat kita bisa membuat aplikasi kamus inggris Indonesia,
yang mungkin dulu kita hanya bisa bertanya bagaimmana cara membuatnya dan hanya bisa bermimpi
dapat mebuatnya. Sekarang kita bisa buat sendiri dengan android. My Dream Come True
Jika baru mulai belajar android dianjurkan untuk membaca tutorial
Aplikasi Android Sederhana - Menghitung Luas Persegi Panjang
Sumber : http://agusharyanto.net/wordpress/?p=317
Tidak ada komentar:
Posting Komentar