Basis data adalah kelompok informasi atau data yang dimodelkan secara logis . Sistem manajemen basis data (DBMS), di sisi lain, adalah program komputer yang berinteraksi dengan basis data. DBMS memungkinkan Anda untuk mengontrol akses ke database, menulis data, menjalankan kueri, dan melakukan tugas-tugas lain yang terkait dengan manajemen database. Meskipun sistem manajemen basis data sering disebut sebagai "basis data," kedua istilah ini tidak dapat dipertukarkan. Basis data dapat berupa kumpulan data apa pun, bukan hanya yang disimpan di komputer, sedangkan DBMS adalah perangkat lunak yang memungkinkan Anda berinteraksi dengan basis data.
SQLite
SQLite adalah RDBMS yang mandiri, berbasis file, dan sepenuhnya open-source yang dikenal dengan portabilitas, keandalan, dan kinerja yang kuat bahkan di lingkungan dengan memori rendah. Transaksi-transaksinya sesuai ACID , bahkan dalam kasus-kasus di mana sistem mengalami crash atau mengalami pemadaman listrik.
Situs web proyek SQLite menggambarkannya sebagai basis data "tanpa server". Sebagian besar mesin basis data relasional diimplementasikan sebagai proses server di mana program berkomunikasi dengan server host melalui komunikasi antarproses yang menyampaikan permintaan. Dengan SQLite, proses apa pun yang mengakses basis data membaca dan menulis ke file disk basis data secara langsung. Ini menyederhanakan proses pengaturan SQLite, karena menghilangkan segala kebutuhan untuk mengkonfigurasi proses server. Demikian juga, tidak ada konfigurasi yang diperlukan untuk program yang akan menggunakan database SQLite: yang mereka butuhkan hanyalah akses ke disk.
SQLite adalah perangkat lunak bebas dan sumber terbuka, dan tidak diperlukan lisensi khusus untuk menggunakannya. Namun, proyek ini memang menawarkan beberapa ekstensi - masing-masing dengan biaya satu kali - yang membantu dengan kompresi dan enkripsi. Selain itu, proyek ini menawarkan berbagai paket dukungan komersial, masing-masing dengan biaya tahunan.
Tipe Data yang Didukung SQLite
SQLite memungkinkan berbagai tipe data, diorganisasikan ke dalam kelas penyimpanan berikut :
Dalam konteks SQLite, istilah "kelas penyimpanan" dan "tipe data" dianggap dapat dipertukarkan. Jika Anda ingin mempelajari lebih lanjut tentang tipe data SQLite dan afinitas tipe SQLite, lihat dokumentasi resmi SQLite tentang masalah ini.
Keuntungan dari SQLite
- Jejak kecil : Sesuai namanya, pustaka SQLite sangat ringan. Meskipun ruang yang digunakan bervariasi tergantung pada sistem tempat pemasangannya, dibutuhkan ruang kurang dari 600KiB. Selain itu, sepenuhnya mandiri, artinya tidak ada dependensi eksternal yang harus Anda instal pada sistem Anda agar SQLite berfungsi.
- User-friendly : SQLite kadang-kadang digambarkan sebagai database "konfigurasi nol" yang siap digunakan di luar kotak. SQLite tidak berjalan sebagai proses server, yang berarti tidak perlu dihentikan, dimulai, atau dimulai ulang dan tidak disertai dengan file konfigurasi apa pun yang perlu dikelola. Fitur-fitur ini membantu merampingkan jalur dari menginstal SQLite hingga mengintegrasikannya dengan aplikasi.
- Portable : Tidak seperti sistem manajemen basis data lainnya, yang biasanya menyimpan data sebagai kumpulan besar file terpisah, seluruh basis data SQLite disimpan dalam satu file. File ini dapat ditemukan di mana saja dalam hierarki direktori, dan dapat dibagikan melalui media yang dapat dipindahkan atau protokol transfer file.
Kerugian dari SQLite
- Konkurensi terbatas : Meskipun beberapa proses dapat mengakses dan meminta basis data SQLite pada saat yang sama, hanya satu proses yang dapat membuat perubahan pada database pada waktu tertentu. Ini berarti SQLite mendukung konkurensi yang lebih besar daripada kebanyakan sistem manajemen database tertanam lainnya, tetapi tidak sebanyak RDBMS klien / server seperti MySQL atau PostgreSQL.
- Tidak ada manajemen pengguna : Sistem basis data sering kali dilengkapi dengan dukungan untuk pengguna , atau koneksi terkelola dengan hak akses yang telah ditentukan sebelumnya untuk database dan tabel. Karena SQLite membaca dan menulis langsung ke file disk biasa, satu-satunya izin akses yang berlaku adalah izin akses khas sistem operasi yang mendasarinya. Ini membuat SQLite pilihan yang buruk untuk aplikasi yang membutuhkan banyak pengguna dengan izin akses khusus.
- Keamanan : Mesin database yang menggunakan server dapat, dalam beberapa kasus, memberikan perlindungan yang lebih baik dari bug dalam aplikasi klien daripada database tanpa server seperti SQLite. Misalnya, pointer liar di klien tidak dapat merusak memori di server. Juga, karena server adalah proses persisten tunggal, database klien-server membatalkan akses data dengan lebih presisi daripada database tanpa server, memungkinkan penguncian yang lebih baik dan konkurensi yang lebih baik.
MySQL
Menurut Peringkat DB-Engine , MySQL telah
menjadi RDBMS open-source paling populer sejak situs tersebut mulai melacak
popularitas basis data pada tahun 2012. MySQL adalah produk yang kaya fitur
yang memperkuat banyak situs web dan aplikasi terbesar di dunia, termasuk
Twitter, Facebook , Netflix, dan Spotify. Memulai dengan MySQL relatif
mudah, sebagian besar berkat dokumentasi
lengkap dan komunitas besar pengembang , serta berlimpahnya
sumber daya terkait MySQL secara online.
MySQL
dirancang untuk kecepatan dan keandalan, dengan mengorbankan kepatuhan penuh
terhadap SQL standar. Pengembang MySQL terus bekerja menuju kepatuhan yang
lebih dekat pada SQL standar, tetapi masih tertinggal dari implementasi SQL
lainnya. Namun, ia datang dengan berbagai mode dan ekstensi SQL yang
membuatnya lebih sesuai. Tidak seperti aplikasi yang menggunakan SQLite,
aplikasi yang menggunakan basis data MySQL mengaksesnya melalui proses daemon
yang terpisah. Karena proses server berada di antara database dan aplikasi
lain, ini memungkinkan untuk kontrol yang lebih besar atas siapa yang memiliki akses
ke database.
MySQL
telah mengilhami banyak aplikasi pihak ketiga, alat, dan perpustakaan
terintegrasi yang memperluas fungsinya dan membantu membuatnya lebih mudah
untuk dikerjakan. Beberapa alat pihak ketiga yang lebih banyak digunakan
adalah phpMyAdmin , DBeaver , dan HeidiSQL .
Jenis Data yang Didukung MySQL
Tipe
data MySQL dapat disusun menjadi tiga kategori besar: tipe numerik, tipe tanggal
dan waktu, dan tipe string.
Keuntungan dari MySQL
- Popularitas dan kemudahan penggunaan : Sebagai salah satu sistem basis data paling populer di dunia, tidak ada kekurangan administrator basis data yang memiliki pengalaman bekerja dengan MySQL. Demikian juga, ada banyak dokumentasi di media cetak dan online tentang cara menginstal dan mengelola database MySQL, serta sejumlah alat pihak ketiga - seperti phpMyAdmin - yang bertujuan untuk menyederhanakan proses memulai dengan database.
- Keamanan : MySQL dilengkapi dengan skrip yang membantu Anda meningkatkan keamanan basis data Anda dengan mengatur tingkat keamanan kata sandi instalasi, menetapkan kata sandi untuk pengguna root , menghapus akun anonim, dan menghapus database uji yang, secara default, dapat diakses oleh semua pengguna. Juga, tidak seperti SQLite, MySQL tidak mendukung manajemen pengguna dan memungkinkan Anda untuk memberikan hak akses berdasarkan pengguna-oleh-pengguna.
- Kecepatan : Dengan memilih untuk tidak mengimplementasikan fitur SQL tertentu, pengembang MySQL dapat memprioritaskan kecepatan. Sementara tes benchmark yang lebih baru menunjukkan bahwa RDBMS lain seperti PostgreSQL dapat menyamai atau setidaknya mendekati MySQL dalam hal kecepatan, MySQL masih memiliki reputasi sebagai solusi database yang sangat cepat.
- Replikasi : MySQL mendukung sejumlah jenis replikasi , yang merupakan praktik berbagi informasi di dua atau lebih host untuk membantu meningkatkan keandalan, ketersediaan, dan toleransi kesalahan. Ini berguna untuk menyiapkan solusi cadangan basis data atau secara horizontal memperbesar basis data seseorang.
Kerugian dari MySQL
- Keterbatasan
yang diketahui : Karena MySQL dirancang untuk kecepatan dan kemudahan penggunaan
daripada kepatuhan SQL penuh, ia hadir dengan batasan fungsional
tertentu. Misalnya, tidak memiliki dukungan
untuk
FULL JOIN
klausa . - Fitur perizinan dan hak milik : MySQL adalah perangkat lunak berlisensi ganda , dengan edisi komunitas sumber terbuka dan gratis dilisensikan di bawah GPLv2 dan beberapa edisi komersial berbayar dirilis di bawah lisensi hak milik. Karena itu, beberapa fitur dan plugin hanya tersedia untuk edisi kesopanan.
- Perkembangan melambat : Karena proyek MySQL diakuisisi oleh Sun Microsystems pada 2008, dan kemudian oleh Oracle Corporation pada 2009, ada keluhan dari pengguna bahwa proses pengembangan untuk DBMS melambat secara signifikan, karena masyarakat tidak lagi memiliki agensi untuk cepat bereaksi terhadap masalah dan mengimplementasikan perubahan.
PostgreSQL
PostgreSQL,
juga dikenal sebagai Postgres, menyebut dirinya sebagai "database
relasional open-source paling canggih di dunia." Itu dibuat dengan
tujuan menjadi sangat fleksibel dan memenuhi standar. PostgreSQL adalah
database objek-relasional, yang berarti bahwa meskipun ini terutama database
relasional, ia juga mencakup fitur - seperti pewarisan tabel dan fungsi yang
berlebihan - yang lebih sering dikaitkan dengan objek database .
Postgres
mampu menangani banyak tugas secara efisien pada saat bersamaan, sebuah
karakteristik yang dikenal sebagai konkurensi . Ini mencapai ini tanpa membaca
kunci berkat penerapan Multiversion
Concurrency Control (MVCC) , yang memastikan atomicity, konsistensi,
isolasi, dan daya tahan transaksi, juga dikenal sebagai kepatuhan ACID.
PostgreSQL
tidak banyak digunakan sebagai MySQL, tetapi masih ada sejumlah alat pihak
ketiga dan perpustakaan yang dirancang untuk menyederhanakan bekerja dengan
PostgreSQL, termasuk pgAdmindan Postbird .
Jenis Data yang Didukung PostgreSQL
PostgreSQL
mendukung tipe data numerik, string, dan tanggal dan waktu seperti
MySQL. Selain itu, ia mendukung tipe data untuk bentuk geometris, alamat
jaringan, string bit, pencarian teks, dan entri JSON, serta beberapa tipe data
istimewa.
Keuntungan PostgreSQL
- Kepatuhan SQL : Lebih daripada SQLite atau MySQL, PostgreSQL bertujuan untuk mematuhi standar SQL. Menurut dokumentasi resmi PostgreSQL , PostgreSQL mendukung 160 dari 179 fitur yang diperlukan untuk kepatuhan penuh terhadap inti SQL: 2011, selain daftar panjang fitur opsional.
- Sumber terbuka dan berbasis komunitas : Proyek sumber terbuka penuh, kode sumber PostgreSQL dikembangkan oleh komunitas besar dan berdedikasi. Demikian pula, komunitas Postgres memelihara dan berkontribusi pada banyak sumber daya online yang menggambarkan cara bekerja dengan DBMS, termasuk dokumentasi resmi , wiki PostgreSQL , dan berbagai forum online.
- Extensible : Pengguna dapat memperluas PostgreSQL secara pemrograman dan on-the-fly melalui operasi berbasis katalog dan penggunaan pemuatan dinamis . Seseorang dapat menunjuk file kode objek, seperti pustaka bersama, dan PostgreSQL akan memuatnya sesuai kebutuhan.
Kerugian PostgreSQL
- Kinerja memori : Untuk setiap koneksi klien baru, PostgreSQL melakukan proses baru. Setiap proses baru dialokasikan sekitar 10MB memori, yang dapat bertambah dengan cepat untuk database dengan banyak koneksi. Dengan demikian, untuk operasi read-heavy sederhana, PostgreSQL biasanya kurang berkinerja daripada RDBMS lainnya, seperti MySQL.
- Popularitas : Meskipun lebih banyak digunakan dalam beberapa tahun terakhir, PostgreSQL secara historis tertinggal dari MySQL dalam hal popularitas. Salah satu konsekuensi dari ini adalah bahwa masih ada lebih sedikit alat pihak ketiga yang dapat membantu mengelola database PostgreSQL. Demikian pula, tidak banyak administrator database dengan pengalaman mengelola database Postgres dibandingkan dengan yang memiliki pengalaman MySQL.
Tidak ada komentar:
Posting Komentar