Minggu, 21 April 2013

Membuat Program Data Entry Part 1

Tak dapat dipungkiri, sudah banyak tutorial-tutorial tentang pembuatan program data entry.  Di sini saya hanya akan sekedar share ilmu yang saya dapat setelah beberapa bulan yang lalu, saya dan teman saya mengerjakan project program data entry. Tulisan ini dibuat agar saya tidak lupa dan mungkin bisa bermanfaat bagi teman-teman yang nyasar ke blog ini.
Selama proses pembuatan program tersebut, kami banyak dibantu oleh berbagai pihak. Dari kakak tingkat (terima kasih atas source code program data entry tahun lalu hehe), mas eko (thanks for video Swing MVC-nya),  stackoverflow  (for the answer of how to fix error in our program), Tanya Java (utk saran data binding-nya), dan lain-lain.
Ok cukup basa-basinya. Dalam tutorial ini terdiri dari beberapa bagian yaitu,
  1. Buat Database
  2. Buat Koneksi database dgn JDBC
  3. Buat Model
  4. Buat DAO + implementasinya
  5. Buat View  + binding dengan Model
  6. Buat Controller + Test
Biar ada gambaran nantinya program jadinya seperti apa, saya kasih screenshoot-nya.
  
Jika ada yang tanya, kok cuma gitu doank sih? Ya memang gitu doank, di sini saya tidak akan membahas program data entry yg kami buat. Design GUI ini saya ambil dari latihan mata kuliah OOP praktek dengan sedikit perubahan. Aplikasi sederhana ini, hanya terdiri dari dua form, Form utk login dan form untuk entry data.

Langkah ke-1: Buat Database

Ok langsung aja kita masuk ke bagian pertama, buat database. Di sini saya akan memakai MySql sebagai DBMS. Untuk pembuatan Data Definition Language (DDL) saya akan buat di netbeans.
Sebenarnya untuk membuat database ini, bisa juga dilakukan lewat MySQL administration yang lain seperti, phpMyAdmin, MySQL Query Browser, atau langsung lewat MySQL Command Line  Client. Silahkan langsung menuju langkah ke-2 jika Anda sudah membuat database lewat tool-tool tersebut. (Saya sendiri lebih senang pakai phpMyAdmin :-) )
Jika ingin mencoba membuat database di netbeans silahkan ikuti langkah berikut ini.
Masuk ke Services Window, klik kanan Menu Databases > Register MySQL Server…
Kemudian akan muncul dialog MySQL Server Properties. Isikan sesuai dengan konfigurasi MySQL Anda. Misal: seperti di bawah ini.
Setelah muncul node MySQL Server di Service Window, klik kanan > Start untuk menjalankan mysql server.  Jika MySQL server sudah berhasil dijalankan, kita buat databasenya, Klik kanan node MySQL server> Create Database… Beri nama database “data_entry_mahasiswa” > OK.
Maka akan terbentuk database baru dengan nama “data_entry_mahasiswa”. Klik kanan pada database tersebut > Connect.
Setelah membuat databasenya, kita buat table-tabelnya. Terdapat dua table, yaitu table user_login dan mahasiswa. Berikut langkah untuk membuatnya.
Pada node connection “jdbc:mysql://localhost:3306/data_entry_mahasiswa [root on Default schema]”  Pilih database yang kita buat, Tables > Execute Command
Isikan SQL command seperti di bawah ini
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
-- tabel user login
CREATE TABLE user_login (
     username VARCHAR(30) NOT NULL,
     password VARCHAR(32) NOT NULL,
     PRIMARY KEY (username)
)ENGINE=INNODB;
 
-- tabel mahasiswa
CREATE TABLE mahasiswa (
     nim CHAR(7) NOT NULL,
     nama VARCHAR(30) NOT NULL,
     jenis_kelamin ENUM("Laki-laki", "Perempuan"),
     alamat VARCHAR(50),
     kelas VARCHAR(4),
     status ENUM("Ikatan Dinas", "Tugas Belajar"),
     PRIMARY KEY (nim)
)ENGINE=INNODB;
 
-- asumsi: yang bisa masuk hanya admin
-- password dienkrip menggunakan MD5
INSERT INTO user_login VALUES("admin", MD5("admin"));
Klik Run SQL seperti yang ditunjukkan pada gambar di atas. Akhirnya kita telah berhasil  membuat database program data entry ini. Sekali lagi untuk membuat database ini, bisa juga dilakukan lewat MySQL administration yang lain seperti, phpMyAdmin, MySQL Query Browser, atau langsung lewat MySQL Command Line  Client.

Langkah ke-2: Buat Koneksi database dgn JDBC

Buat Project baru di Netbeans (Java Application), terserah namanya apa.
Karena kita mau pake MySQL, maka kita harus menambahkan driver MySQL JDBC ke project kita. Klik kanan > Folder Libraries > Add Library > MySQL JDBC Driver.
     
Setelah itu buat class DatabaseUtility, code-nya seperti di bawah ini.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
/**
 *  For more information
 *  my email rn.hindarwan@programmer.net
 */
package com.wordpress.erenha.java.desktop.entry.utility;
 
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
 
/**
 * DatabaseUtility.java
 * Class yang digunakan untuk membuat koneksi ke database
 * @author Hindarwan
 */
public class DatabaseUtility {
 
    private static Connection connection;
    //driver mysql
    private static final String DB_DRIVER = "com.mysql.jdbc.Driver";
    //mysql url pattern = jdbc:mysql://nama_db_server:db_port/nama_db
    private static final String DB_URL = "jdbc:mysql://localhost:3306/data_entry_mahasiswa";
    //database user default 'root'
    private static final String USER = "root";
    //no password
    private static final String PASSWORD = "";
 
    /**
     * Membuat koneksi ke database sesuai dengan nilai dari
     * final atribut class ini e.g. USER = "root"
     * @return koneksi yang berhasil dibuat
     * @throws SQLException jika koneksi gagal dibuat
     */
    public static Connection getConnection() throws SQLException {
        if (connection == null) {
            try {
                //load driver
                Class.forName(DB_DRIVER).newInstance();
                //koneksi ke database
                connection = DriverManager.getConnection(DB_URL, USER, PASSWORD);
            } catch (InstantiationException ex) {
                System.out.println(ex.getMessage());
            } catch (IllegalAccessException ex) {
                System.out.println(ex.getMessage());
            } catch (ClassNotFoundException ex) {
                System.out.println(ex.getMessage());
            }
        }
        return connection;
    }
}
Selesai sudah pembuatan database + koneksinya dengan JDBC.
bersambung ke artikel BERSAMBUNG....,

Tidak ada komentar:

Posting Komentar