Skip to main content

[Dokumentasi] Menggunakan MongoDB sebagai Database Engine Node.js

Apa itu MongoDB? MongoDB adalah Dokumen Database open source dan NoSQL database.
Berikut ini penjelasan dari MongoDB (source : https://www.mongodb.org/ )
MongoDB (from "humongous") is an open-source document database, and the leading NoSQL database. Written in C++, MongoDB features:
  • GridFS »
    Store files of any size without complicating your stack.
Berikut ini penggunaan MongoDB dan koneksinya dengan Node.js
  1. Instalasi
  • Download installer MongoDB pada https://www.mongodb.org/downloads
  • Pilih installer yang sesuai dengan sistem operasi yang digunakan
  • Instal MongoDB pada lokal komputer
  1. Contoh sederhana penggunaan MongoDB
  • Tentukan direktori penyimpanan database (dalam contoh ini direktori nya adalah c:\mongodb\mongodata)
  • Buka command prompt, ketikkan perintah berikut untuk menentukan lokasi database di atas
mongod --dbpath c:\mongodb\mongodata
  • Jalankan Mongo dengan mengetikkan mongo pada commandprompt, jika berhasil maka akan tampil pesan berikut :
MongoDB shell version: 2.4.5
connecting to: test
  • Di atas terlihat secara otomatis akan terkoneksi pada database test. Meskipun di atas terlihat telah terkoneksi ke database test, namun sebenarnya database test tersebut belum benar-benar terbuat, sampai database tersebut benar-benar telah terisi. Baik, kita abaikan saja database test.
  • Kita akan coba menggunakan database dengan nama nodetest1, ketik perintah berikut
use nodetest1
  • Seperti database test tadi, database nodetest1 yang kita gunakan belum benar-benar terbuat. Untuk itu kita akan mengisi database ini ke dalam collection. Ketikkan perintah berikut :
db.usercollection.insert({ "username" : "testuser1", "email" : "testuser1@testdomain.com" })
  • Sebagai catatan, database MongoDB terdiri dari collection-collection. Namun tidak ada langkah khusus untuk membuat collection tersebut.
  • Untuk melihat isi dari collection tadi, ketik perintah berikut :
db.usercollection.find().pretty()
  • Hasilnya akan seperti berikut :
{
"_id":ObjectId("5202b481d2184d390cbf6eca"),
"username":"testuser1",
"email":"testuser1@testdomain.com"
}
  • Tambahkan lagi data ke usercollection
newstuff = [{ "username" : "testuser2", "email" : "testuser2@testdomain.com" }, { "username" : "testuser3", "email" : "testuser3@testdomain.com" }]
db
.usercollection.insert(newstuff);
  • Jika dilihat isi dari collection, maka akan tampil seperti data berikut :
{
"_id":ObjectId("5202b481d2184d390cbf6eca"),
"username":"testuser1",
"email":"testuser1@testdomain.com"
}
{
"_id":ObjectId("5202b49ad2184d390cbf6ecb"),
"username":"testuser2",
"email":"testuser2@testdomain.com"
}
{
"_id":ObjectId("5202b49ad2184d390cbf6ecc"),
"username":"testuser3",
"email":"testuser3@testdomain.com"
}
  1. Contoh koneksi Node.js ke database pada MongoDB
Pada tahap ini, akan ditampilkan data dari database MongoDB ke browser.
  • Berikut struktur html yang akan digenerate untuk ditampilkan ke browser

  • testuser1


  • testuser2

  • testuser3

    • Buka windows explorer, masuk kembali ke direktori dimana aplikasi disimpan (D:\NodeJS\Samples\FirstProject). Edit file app.js dengan menggunakan Text Editor
    • Perhatikan potongan kode berikut :
    var express=require('express');
    var path=require('path');
    var favicon=require('serve-favicon');
    var logger=require('morgan');
    var cookieParser=require('cookie-parser');
    var bodyParser=require('body-parser');
    Tambahkan 3 baris kode di bawahnya, sehingga akan tampak seperti berikut :
    var express=require('express');
    var path=require('path');
    var favicon=require('serve-favicon');
    var logger=require('morgan');
    var cookieParser=require('cookie-parser');
    var bodyParser=require('body-parser');
    // New Code
    var mongo=require('mongodb');
    var monk=require('monk');
    var db= monk('localhost:27017/nodetest1');
    • Kemudian perhatikan potongan kode berikut :
    app.use('/', routes);
    app.use('/users', users);
    Tambahkan beberapa baris kode di atasnya / sebelumnya
    // Make our db accessible to our router
    app.use(function(req,res,next){
    req.db= db;
    next()
    ;});
    app.use('/', routes);
    app.use('/users', users);
    Pastikan kode yang baru diletakkan sebelum app.use(‘/’, routes);
    • Simpan file app.js dan tutup
    • Buka folder routes, edit file index.js. Tambahkan kode berikut (Mulai dari New Code sampai dengan End New Code) :
    var express = require('express');
    var router = express.Router();
    //New Code
    /* GET Userlist page. */
    router.get('/userlist', function(req, res) {
    var db = req.db;
    var collection = db.get('usercollection');
    collection.find({},{},function(e,docs){
    res.render('userlist', {
    "userlist" : docs
    });
    });
    });
    //End New Code
    /* GET Hello World page. */
    router.get('/helloworld', function(req, res) {
    res.render('helloworld', { title: 'Hello, World!' })
    });
    /* GET home page. */
    router.get('/', function(req, res) {
    res.render('index', { title: 'Express' });
    });
    module.exports = router;
    Simpan dan tutup.
    • Dari folder routes, pindah ke folder views. Di dalam folder views, buat file view baru dengan nama userlist.jade. Ketikkan kode berikut :
    extends layout
    block content
    h1.
    UserList
    ul
    each user, i in userlist
    li
    a(href="mailto:#{user.email}")= user.username
    Simpan dan tutup.
    • Buka kembali command prompt, dengan posisi di direktori penyimpanan (D:\NodeJS\Samples\FirstProject). Jalankan npm dengan mengetik perintah npm start
    • Buka browser, ketikkan http://localhost:3000/userlist
    • Browser akan menampilkan data user yang telah diinput pada collection MongoDB
    4. Input data ke database pada MongoDB
    • Pertama kita buat form input nya. Untuk membuat form tersebut, edit kembali file index.js. Tambahkan kode berikut (Mulai dari New Code sampai dengan End New Code) :
    var express = require('express');
    var router = express.Router();
    //New Code
    /* GET New User page. */
    router.get('/newuser', function(req, res) {
    res.render('newuser', { title: 'Add New User' });
    });
    //End New Code
    /* GET Userlist page. */
    router.get('/userlist', function(req, res) {
    var db = req.db;
    var collection = db.get('usercollection');
    collection.find({},{},function(e,docs){
    res.render('userlist', {
    "userlist" : docs
    });
    });
    });
    /* GET Hello World page. */
    router.get('/helloworld', function(req, res) {
    res.render('helloworld', { title: 'Hello, World!' })
    });
    /* GET home page. */
    router.get('/', function(req, res) {
    res.render('index', { title: 'Express' });
    });
    module.exports = router;
    Simpan file dan tutup.
    • Kemudian pindah ke folder views. Tambahkan file dengan nama newuser. Masukkan kode berikut :
    extends layout
    block content
    h1= title
    form#formAddUser(name="adduser",method="post",action="/adduser")
    input#inputUserName(type="text", placeholder="username", name="username")
    input#inputUserEmail(type="text", placeholder="useremail", name="useremail")
    button#btnSubmit(type="submit") submit
    • Buka kembali command prompt, jalankan kembali npm dengan mengetik npm start.
    • Buka browser, ketik http://localhost:3000/newuser. Browser akan menampilkan form input data.
    • Untuk menginput data yang telah diinput pada form, maka edit kembali file index.js pada forlder routes. Tambahkan kode berikut (mulai dari New Code sampai dengan End New Code) :
    var express = require('express');
    var router = express.Router();
    //New Code
    /* POST to Add User Service */
    router.post('/adduser', function(req, res) {
    // Set our internal DB variable
    var db = req.db;
    // Get our form values. These rely on the "name" attributes
    var userName = req.body.username;
    var userEmail = req.body.useremail;
    // Set our collection
    var collection = db.get('usercollection');
    // Submit to the DB
    collection.insert({
    "username" : userName,
    "email" : userEmail
    }, function (err, doc) {
    if (err) {
    // If it failed, return error
    res.send("There was a problem adding the information to the database.");
    }
    else {
    // If it worked, set the header so the address bar doesn't still say /adduser
    res.location("userlist");
    // And forward to success page
    res.redirect("userlist");
    }
    });
    });
    //End New Code
    /* GET New User page. */
    router.get('/newuser', function(req, res) {
    res.render('newuser', { title: 'Add New User' });
    });
    /* GET Userlist page. */
    router.get('/userlist', function(req, res) {
    var db = req.db;
    var collection = db.get('usercollection');
    collection.find({},{},function(e,docs){
    res.render('userlist', {
    "userlist" : docs
    });
    });
    });
    /* GET Hello World page. */
    router.get('/helloworld', function(req, res) {
    res.render('helloworld', { title: 'Hello, World!' })
    });
    /* GET home page. */
    router.get('/', function(req, res) {
    res.render('index', { title: 'Express' });
    });
    module.exports = router;
    Simpan file dan tutup.
    • Jalankan kembali npm pada browser, dengan mengetikkan npm start
    • Buka browser, ketik http://localhost:3000/newuser. Browser akan menampilkan form input data.
    • Coba lakukan input data pada form, lalu Klik Submit. Jika berhasil, maka data akan tersimpan dan browser akan menampilkan seluruh data dari collection di database termasuk dengan data yang baru diinput.

    Comments

    Popular posts from this blog

    [Dokumentasi] Reporting Program VB6 dengan Crystal Report 8.5 menggunakan TTX File (II)

    Dalam tulisan kali ini, kita akan menampilkan data dari program aplikasi yang kita buat dengan VB6 ke laporan Crystal Report (TTX File). Di bagian sebelumnya, sudah disampaikan langkah-langkah pembuatan laporan Crystal Report dengan TTX File. Untuk menghubungkan laporan tersebut dari program aplikasi yang kita buat, dapat mengikuti langkah-langkah berikut : 1. Buka IDE Ms. VB 6, pilih New - Standard Exe, kemudian klik tombol Open 2. Pilih menu Project - Component (Ctrl+T), tab Controls akan menampilkan daftar komponen teregister yang dapat kita gunakan untuk program aplikasi kita, ceklis komponen Crystal Report Viewer Control, kemudian klik tombol OK 3. Pilih menu Project - References, ceklis Crystal Reports 8.5 ActiveX Designer Run Time Library dan Microsoft ActiveX Data Objects 2.x Library, kemudian klik tombol OK 4. Pada Toolbox akan menambah 1 komponen dengan nama CRViewer, drag komponen tersebut dan drop di form yang kita gunakan. 5. Atur tata letak komponen tersebut pada for...

    [Dokumentasi] Contoh sederhana export excel dari Visual Basic 6.0

    Dalam pemrograman basisdata, sebagai programmer, kita dituntut untuk dapat menghasilkan output berupa laporan. Cara menghasilkan laporan tersebut tentunya berbeda-beda. Salah satu cara menghasilkan output laporan adalah menampilkan laporan tersebut ke excel. Berikut ini diuraikan langkah-langkah pembuatan output excel sederhana dengan menggunakan Visual Basic 6.0 : Buat satu project baru pada visual basic 6.0 Tambahkan 1 CommandButton pada form dan beri nama Command1 Buka code viewer pada form yang telah disediakan CommandButton tadi Deklarasikan object untuk menghasilkan file excel Dim oExcel As Object Dim oBook As Object Dim oSheet As Object Double Click pada CommandButton tadi untuk menambahkan code pada event click'- Set object yang telah dideklarasikan sebelumnya untuk membuat objek Excel Set oExcel = CreateObject("Excel.Application") Set oBook = oExcel.Workbooks.Add Set oSheet = oBook.Worksheets(1) '- Lakukan pengaturan untuk masing-masing kolom o...

    Apa itu 5G?

    Generasi berikutnya dari teknologi selular hadir dengan kosa katanya sendiri. Berikut adalah daftar istilah praktis yang terus bermunculan. Definisi singkat tentang 5G: Ini adalah teknologi seluler generasi berikutnya (kelima) yang menjanjikan peningkatan kecepatan, jangkauan, dan daya tanggap jaringan nirkabel. Seberapa cepat kita bicara? Pikirkan 10 sampai 100 kali lebih cepat daripada koneksi seluler khas Anda, dan bahkan lebih cepat dari apapun yang bisa Anda dapatkan dengan kabel fiber optik fisik yang masuk ke rumah Anda. (Anda dapat mendownload nilai musim ini dalam hitungan detik.). Ini bukan hanya tentang supercharging koneksi telepon Anda ke jaringan; 5G dipandang sebagai teknologi dasar yang bagi orang-orang untuk secara nirkabel mengalirkan konten virtual reality definisi tinggi ke dalam headset mereka. Dengan kata lain, ini akan menjadi besar. Jaringan 5G awal akan muncul segera tahun depan mulai dari operator termasuk Verizon dan AT & T, sekitar 2019 samp...