Skip to main content

Aplikasi Database CRUD (VB6 + Ms. Access + Crystal Report 8)



Assalamualaikum wr. wb. sobat yadishare, apa kabar ? Di artikel kali ini saya akan membagikan tutorial tentang bagaimana cara membuat aplikasi CRUD (create, read, update, dan delete) menggunakan aplikasi atau bahasa pemrograman visual basic 6.0 dan database yang akan saya gunakan adalah database microsoft access. Untuk pembuatan laporannya nanti saya akan menggunakan aplikasi crystal report versi 8. Oke topiknya kali ini adalah membuat aplikasi crud sederhana tentang data pegawai. Namun di dalam aplikasi ini nanti teman-teman akan mempunyai opsi yang cukup lengkap. Selain ada fitur crud dan filtering data, teman-teman bisa langsung mencetak laporannya ke dalam printer. Keren kan ???

Ok langsung saja kita mulai tutorialnya. Untuk membuat aplikasi crud ini, dibutuhkan sebuah database microsoft access. Nah untuk mempersingkat waktu, berhubung saya sudah membuatkan tutorialnya di artikel dan video saya sebelumnya, jadi saya tidak akan bahas lagi disini. Teman-teman bisa langsung baca tutorial mengenai cara membuat database dan table pegawai di microsoft access buat yang senang membaca, dan buat teman-teman yang lebih senang menonton video tutorial bisa langsung menyimak tutorialnya melalui video berikut ini :



Sekarang kita akan masuk ke dalam proses pembuatan aplikasinya menggunakan aplikasi visual basic 6. Kita buka dulu ya aplikasinya...




Kalau sudah silahkan pilih VB Enterprise Edition Controls dan click open. Terus ganti name dari form1 menjadi frmpegawai dan silahkan teman-teman design form1 nya menjadi seperti ini yah :



Terus tambahkan lagi sebuah form untuk digunakan sebagai form entry dan edit pegawai. Ganti name dari form2 menjadi frmPegawaiEntry dan silahkan teman-teman design form2 nya menjadi seperti ini yah :



Kalau teman-teman lihat di list components yang saya gunakan di bawah ini, hanya ada 3 component sebenarnya. Jadi teman-teman bisa remove component-component yang tidak dibutuhkan ya...




Di bagian references kita membutuhkan Microsoft ActiveX Data Objects 2.x library (ADODB) untuk digunakan sebagai library database yang akan kita gunakan di dalam program. Berikut adalah references yang saya gunakan :




Kemudian add sebuah module ke dalam project dan tambahkan 3 buah variable ke dalamnya. Berikut tampilannya :




Sekarang buka frmpegawai dan masukkan coding berikut ini :

[code language="vb"] Option Explicit Private Sub CmdAddPegawai_Click() blnentry = True frmPegawaiEntry.Show vbModal End Sub Private Sub Command1_Click() With CrystalReport1 .ReportFileName = App.Path & "\Report Daftar Pegawai.rpt" .Connect = App.Path & "dbpegawai.mdb" .DiscardSavedData = True .RetrieveDataFiles .ReportSource = 0 .SQLQuery = "SELECT * FROM pegawai ORDER by nama_lengkap" .ReportTitle = "Report Data Pegawai" .Destination = crptToWindow .WindowState = crptMaximized .Action = 1 End With End Sub Private Sub vsfPegawai_DblClick() If vsfPegawai.Rows = 0 Then Exit Sub blnentry = False frmPegawaiEntry.Show vbModal End Sub Private Sub CmdApply_Click() Call ShowData End Sub Private Sub cmdClose_Click() End End Sub Private Sub CmdDelete_Click() On Error GoTo Err_Hand Dim i As Integer Dim BlnAda As Boolean 'Validasi If vsfPegawai.Rows = 0 Then MsgBox "Silahkan pilih pegawai yang akan dihapus !", vbInformation, "Pesan": Exit Sub For i = 1 To vsfPegawai.Rows - 1 If vsfPegawai.TextMatrix(i, 0) = True Then BlnAda = True Exit For End If Next If BlnAda = False Then MsgBox "Silahkan pilih pegawai yang akan dihapus !", vbInformation, "Pesan": Exit Sub If MsgBox("Anda yakin ingin menghapus semua pegawai yang anda pilih ?", vbExclamation + vbYesNo, "Konfirmasi") = vbNo Then Exit Sub Dim cntrx As New ADODB.Connection cntrx.Open Conn cntrx.BeginTrans For i = 1 To vsfPegawai.Rows - 1 If vsfPegawai.TextMatrix(i, 0) = True Then cntrx.Execute "DELETE from pegawai WHERE nip='" & vsfPegawai.TextMatrix(i, 2) & "'" End If Next cntrx.CommitTrans cntrx.Close ShowData MsgBox "Semua data pegawai yang anda pilih telah terhapus !", vbExclamation, "Pesan" Exit Sub Err_Hand: cntrx.RollbackTrans MsgBox Err.Description, vbCritical, "Error No. " & CStr(Err.Number) End Sub Private Sub Form_Load() If Conn.State = adStateOpen Then Conn.Close Conn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & App.Path & "\dbpegawai.mdb;" CboKelamin.ListIndex = 0 CboStatus.ListIndex = 0 Call ShowData End Sub Sub ShowData() Dim strSQL As String Dim rsMn As New ADODB.Recordset Dim i As Integer strSQL = "Select * from pegawai where id>0 " If txtnip.Text "" Then strSQL = strSQL & " and nip like '%" & txtnip.Text & "%' " If txtnama.Text "" Then strSQL = strSQL & " and nama_lengkap like '%" & txtnama.Text & "%' " If CboKelamin.Text "All" Then strSQL = strSQL & " and kelamin = '" & CboKelamin.Text & "' " If CboStatus.Text "All" Then strSQL = strSQL & " and status = '" & CboStatus.Text & "' " strSQL = strSQL & " order by nama_lengkap" rsMn.Open strSQL, Conn, adOpenForwardOnly, adLockReadOnly With vsfPegawai i = 1 .Rows = i Do While Not rsMn.EOF i = .Rows - 1 i = i + 1 .AddItem i .TextMatrix(i, 0) = 0 .TextMatrix(i, 1) = i .TextMatrix(i, 2) = rsMn("nip") .TextMatrix(i, 3) = rsMn("nama_lengkap") .TextMatrix(i, 4) = rsMn("tempat_lahir") .TextMatrix(i, 5) = rsMn("tgl_lahir") .TextMatrix(i, 6) = rsMn("kelamin") .TextMatrix(i, 7) = rsMn("status") .TextMatrix(i, 8) = Format(rsMn("createdate"), "dd-mmm-yyyy hh:mm:ss") .TextMatrix(i, 9) = Format(rsMn("lastupdate"), "dd-mmm-yyyy hh:mm:ss") rsMn.MoveNext Loop rsMn.Close LblRecord.Caption = .Rows - 1 End With End Sub [/code]

Sekarang buka frmpegawaientry dan masukkan coding berikut ini :

[code language="vb"] Option Explicit Private Sub CmdAdd_Click() On Error GoTo Err_Hand Dim strSQL As String Dim rs As New ADODB.Recordset If txtnip.Text = "" Then MsgBox "Harap isi nip", vbExclamation, "Pesan" txtnip.SetFocus Exit Sub End If If txtnama.Text = "" Then MsgBox "Harap isi nama lengkap", vbExclamation, "Pesan" txtnama.SetFocus Exit Sub End If If txttempat.Text = "" Then MsgBox "Harap isi tempat lahir", vbExclamation, "Pesan" txttempat.SetFocus Exit Sub End If If DTLahir.Value = "" Then MsgBox "Harap isi tanggal lahir", vbExclamation, "Pesan" DTLahir.SetFocus Exit Sub End If If CboKelamin.Text = "" Then MsgBox "Harap isi jenis kelamin", vbExclamation, "Pesan" CboKelamin.SetFocus Exit Sub End If If CboStatus.Text = "" Then MsgBox "Harap isi status", vbExclamation, "Pesan" CboStatus.SetFocus Exit Sub End If If blnentry = True Then strSQL = "Select nip from pegawai where nip = '" & txtnip.Text & "'" rs.Open strSQL, Conn, adOpenDynamic, adLockOptimistic If Not rs.EOF Then MsgBox "Data pegawai dengan NIP : " & txtnip.Text & " sudah ada !", vbInformation, "Pesan" rs.Close Set rs = Nothing Exit Sub End If rs.Close Set rs = Nothing If MsgBox("Anda yakin ingin menyimpan data pegawai ini ?", vbInformation + vbYesNo, "Tambah Pegawai") = vbNo Then Exit Sub rs.CursorLocation = adUseClient rs.Open "Select * from pegawai", Conn, adOpenDynamic, adLockOptimistic rs.AddNew rs("nip") = txtnip.Text rs("nama_lengkap") = txtnama.Text rs("tempat_lahir") = txttempat.Text rs("tgl_lahir") = DTLahir.Value rs("kelamin") = CboKelamin.Text rs("status") = CboStatus.Text rs("createdate") = Now rs.Update rs.Close Set rs = Nothing MsgBox "Data pegawai sudah tersimpan !", vbInformation Else If MsgBox("Anda yakin ingin menyimpan perubahan tersebut ?", vbInformation + vbYesNo, "Update Pegawai") = vbNo Then Exit Sub strSQL = "UPDATE pegawai Set nama_lengkap = '" & txtnama.Text & "'" & _ ",tempat_lahir='" & txttempat.Text & "'" & _ ",tgl_lahir='" & DTLahir.Value & "'" & _ ",kelamin='" & CboKelamin.Text & "'" & _ ",status='" & CboStatus.Text & "'" & _ ", lastupdate = now() WHERE nip='" & txtnip.Text & "'" Conn.Execute strSQL MsgBox "Data pegawai sudah diupdate !", vbInformation End If frmpegawai.ShowData Unload Me Exit Sub Err_Hand: MsgBox Err.Description, vbCritical, "Error Code:" & Err.Number End Sub Private Sub cmdClose_Click() Unload Me End Sub Private Sub Form_Load() CboKelamin.ListIndex = 0 CboStatus.ListIndex = 0 If blnentry = True Then txtnip.Enabled = True CmdAdd.Caption = "Simpan" Else txtnip.Enabled = False CmdAdd.Caption = "Update" Dim strSQL As String Dim rs As New ADODB.Recordset strSQL = "select * from pegawai Where nip = '" & frmpegawai.vsfPegawai.TextMatrix(frmpegawai.vsfPegawai.Row, 2) & "'" rs.Open strSQL, Conn, adOpenDynamic, adLockOptimistic If Not rs.EOF Then txtnip.Text = rs("nip") txtnama.Text = rs("nama_lengkap") txttempat.Text = rs("tempat_lahir") DTLahir.Value = rs("tgl_lahir") CboKelamin.Text = rs("kelamin") CboStatus.Text = rs("status") End If rs.Close Set rs = Nothing End If End Sub Private Sub txtnip_KeyPress(KeyAscii As Integer) KeyAscii = Asc(UCase(Chr(KeyAscii))) If KeyAscii = 13 Then Set WshShell = CreateObject("WScript.Shell") WshShell.SendKeys "{tab}" End If End Sub Private Sub txtnama_KeyPress(KeyAscii As Integer) KeyAscii = Asc(UCase(Chr(KeyAscii))) If KeyAscii = 13 Then Set WshShell = CreateObject("WScript.Shell") WshShell.SendKeys "{tab}" End If End Sub Private Sub txttempat_KeyPress(KeyAscii As Integer) KeyAscii = Asc(UCase(Chr(KeyAscii))) If KeyAscii = 13 Then Set WshShell = CreateObject("WScript.Shell") WshShell.SendKeys "{tab}" End If End Sub [/code]

Gimana ? Mudah atau bingung sob ? Kalau kamu masih bingung lihat saja video tutorialnya berikut ini :








Nah terus gimana mas cara membuat laporannya menggunakan crystal report ? Simak aja video tutorialnya langsung disini ya...






Oke sobat yadishare, semoga artikel dan tutorialnya kali ini bermanfaat buat kita semua ya :) sampai jumpa di tutorial-tutorial selanjutnya. Assalamualaikum wr. wb.

Comments

Popular posts from this blog

Mengirim Email dengan Delphi XE Menggunakan Account Google

Kemarin kita sudah membahas mengenai bagaimana caranya mengirim email melalui aplikasi yang dibuat dengan menggunakan VB.NET . Nah sekarang bagaimana caranya mengirim email tapi melalui aplikasi Delphi XE? Untuk mengirim email melalui Delphi XE sebenarnya mudah sekali. Caranya juga hampir mirip dengan VB.NET kok. Component yang dibutuhkan antara lain adalah TIdSMTP, TIdMessage dan TIdSSLIOHandlerSocketOpenSSL. Tanpa component-component tersebut kamu tidak akan dapat mengirimkan email. Selain component yang saya sebutkan diatas, tentu kamu akan membutuhkan koneksi internet. Tanpa itu mustahil email dapat dikirim ke alamat tujuan. Sebenarnya kamu juga dapat menambahkan class dari masing-masing component diatas ke dalam uses tanpa harus menggunakan component. Hal lain yang sangat penting yang mesti kamu pahami adalah untuk mengirimkan sebuah email dibutuhkan yang namanya email sender (email si pengirim), email recipient (email si penerima), email cc (optional), email bcc (optional) dan SM

Penjumlahan Inputbox Secara Otomatis Di HTML, Php, Dan JQuery

Hai sobat yadishare apa kabar? Sudah hari sabtu lagi nih. Iseng-iseng ah pengen nulis mengenai html dan jquery. Ketika kita membangun sebuah aplikasi menggunakan php, seringkali kita harus membuat sebuah penjumlahan antar textbox secara otomatis agar memudahkan user. Misalnya kita memiliki 3 buah inputbox yang kita buat dengan menggunakan HTML yang terdiri dari sub total, ppn, dan grand total. Kemudian setiap kali kita menginputkan angka ke dalam textbox sub total dan textbox ppn tersebut, kita ingin textbox grand total jumlahnya terhitung secara otomatis agar dapat memudahkan user. Lalu bagaimana caranya? Nah untuk dapat melakukannya, kita pasti butuh cara yang mudah dan cepat bukan? Ada banyak cara yang dapat kita lakukan untuk mewujudkan hal tersebut. Salah satunya adalah dengan menggunakan bantuan JQuery. Pertama kalian bisa download file jquery.js disini . Masukkan ke dalam folder assets/js. Kalian juga dapat menambahkan script berikut ini tanpa harus mendownload f