MySQL: Perbedaan antara revisi
Konten dihapus Konten ditambahkan
penambahan eksternal link ke monty |
|||
(120 revisi perantara oleh 79 pengguna tidak ditampilkan) | |||
Baris 1:
{{distinguish|Microsoft SQL Server}}
{{Infobox Software
|name = MySQL
|screenshot = [[Berkas:MySQL.png|200px]]
|caption = Logo MySQL
|developer = [[Oracle Corporation|Oracle]] (sebelumnya [[Sun Microsystems|Sun]], sebelumnya [[MySQL AB]])
|released = {{start-date|23 May 1995}}
|latest_release_version = 8.0.30
|latest_release_date = {{release date and age|df=yes|2022|07|06}}<ref>{{cite web|url=https://dev.mysql.com/doc/relnotes/mysql/8.0/en/news-8-0-16.html |title=Changes in MySQL 8.0.16 |publisher=[[Oracle Corporation]] |accessdate=27 may 2019}}</ref>
<!--|latest_preview_version = 5.6.5
|latest_preview_date = {{release date and age|df=yes|2012|04|10}}-->
|frequently updated = yes
|programming language = [[C (programming language)|C]], [[C++]]<ref>{{cite web|title=MySQL|url=http://www.ohloh.net/p/mysql/analyses/latest|work=Ohloh.net|access-date=2012-05-15|archive-date=2012-07-07|archive-url=https://web.archive.org/web/20120707023450/http://www.ohloh.net/p/mysql/analyses/latest|dead-url=yes}}</ref>
|operating_system = [[antar-platform]]
|genre = [[Relational database management system|RDBMS]]
|license = [[GPL]] atau [http://www.mysql.com/company/legal/licensing/commercial-license.html Lisensi Komersial]
|website = [http://www.mysql.com/ www.mysql.com]<br/>[http://dev.mysql.com/ dev.mysql.com]
}}
'''MySQL''' adalah sebuah [[perangkat lunak]] sistem manajemen [[basis data]] [[SQL]] ([[bahasa Inggris]]: ''database management system'') atau DBMS yang [[multialur]], [[multipengguna]], dengan sekitar 6 juta instalasi di seluruh dunia. [[MySQL AB]] membuat MySQL tersedia sebagai [[perangkat lunak gratis]] di bawah lisensi [[GNU General Public License]] (GPL), tetapi mereka juga menjual di bawah lisensi komersial untuk kasus-kasus di mana penggunaannya tidak cocok dengan penggunaan GPL.
Tidak sama dengan proyek-proyek seperti [[Apache HTTP Server|Apache]],
== Gambaran ==
MySQL adalah
Kehandalan suatu sistem basisdata ([[DBMS]]) dapat diketahui dari cara kerja pengoptimasi-nya dalam melakukan proses perintah-perintah SQL yang dibuat oleh pengguna maupun program-program aplikasi yang memanfaatkannya. Sebagai peladen basis data, MySQL mendukung operasi basisdata transaksional maupun operasi basisdata non-transaksional. Pada modus operasi non-transaksional, MySQL dapat dikatakan unggul dalam hal unjuk kerja dibandingkan perangkat lunak peladen basisdata kompetitor lainnya. Namun pada modus non-transaksional tidak ada jaminan atas reliabilitas terhadap data yang tersimpan, karenanya modus non-transaksional hanya cocok untuk jenis aplikasi yang tidak membutuhkan reliabilitas data seperti aplikasi blogging berbasis web ([[wordpress]]), [[Content management system|CMS]], dan sejenisnya. Untuk kebutuhan sistem yang ditujukan untuk bisnis sangat disarankan untuk menggunakan modus basisdata transaksional, hanya saja sebagai konsekuensinya unjuk kerja MySQL pada modus transaksional tidak secepat unjuk kerja pada modus non-transaksional.
== Sejarah ==
[[Berkas:Monty-Widenius-David-Axmark-MySQL-2003-05-09.jpg|jmpl|200px|David Axmark (kiri) dan Michael "Monty" Widenius, Pendiri MySQL AB, dalam sebuah konferensi]]
MySQL pada awalnya diciptakan pada tahun 1979, oleh Michael "[[:en:Michael_Widenius|Monty]]" Widenius, seorang programmer komputer asal [[Swedia]]. Monty mengembangkan sebuah sistem database sederhana yang dinamakan UNIREG yang menggunakan koneksi low-level ISAM database engine dengan indexing. Pada saat itu Monty bekerja pada perusahaan bernama TcX di Swedia.
TcX pada tahun 1994 mulai mengembangkan aplikasi berbasis web, dan berencana menggunakan UNIREG sebagai sistem database. Namun sayangnya, UNIREG dianggagap tidak cocok untuk database yang dinamis seperti web.
TcX kemudian mencoba mencari alternatif sistem database lainnya, salah satunya adalah mSQL (miniSQL). Namun mSQL versi 1 ini juga memiliki kekurangan, yaitu tidak mendukung indexing, sehingga performanya tidak terlalu bagus.
Dengan tujuan memperbaiki performa mSQL, Monty mencoba menghubungi David Hughes (programmer yang mengembangkan mSQL) untuk menanyakan apakah ia tertarik mengembangkan sebuah konektor di mSQL yang dapat dihubungkan dengan UNIREG ISAM sehingga mendukung indexing. Namun saat itu Hughes menolak, dengan alasan sedang mengembangkan teknologi indexing yang independen untuk mSQL versi 2.
Dikarenakan penolakan tersebut, David Hughes, TcX (dan juga Monty) akhirnya memutuskan untuk merancang dan mengembangkan sendiri konsep sistem database baru. Sistem ini merupakan gabungan dari UNIREG dan mSQL (yang source codenya dapat bebas digunakan). Sehingga pada May 1995, sebuah RDBMS baru, yang dinamakan MySQL dirilis.
David Axmark dari Detron HB, rekanan TcX mengusulkan agar MySQL di ‘jual’ dengan model bisnis baru. Ia mengusulkan agar MySQL dikembangkan dan dirilis dengan gratis. Pendapatan perusahaan selanjutnya di dapat dari menjual jasa “support” untuk perusahaan yang ingin mengimplementasikan MySQL. Konsep bisnis ini sekarang dikenal dengan istilah Open Source.
Pada tahun 1995 itu juga, TcX berubah nama menjadi MySQL AB, dengan Michael Widenius, David Axmark dan Allan Larsson sebagai pendirinya. Titel “AB” di belakang MySQL, adalah singkatan dari “Aktiebolag”, istilah PT ([[Perseroan terbatas|Perseroan Terbatas]]) bagi perusahaan Swedia.<ref>http://www.duniailkom.com/tutorial-mysql-sejarah-dan-masa-depan-mysql/</ref>
=== Akuisisi oleh Sun dan Oracle ===
Pada tanggal 16 Januari 2008 Sun Microsystems, Inc mengumumkan aksi korporasi - akuisisi terhadap MySQL AB sehingga menjadikan Sun sebagai salah satu perusahaan dengan produk platform open source terbesar seperti Java, OpenSolaris dan akhirnya MySQL.
Berselang setahun kemudian, tepatnya pada tanggal 20 April 2009 giliran Oracle melakukan akusisi terhadap Sun Microsystems. Sejak saat itu berkembang isu Oracle - yang memiliki produk database yang berkompetisi dengan MySQL - akan mematikan MySQL. Namun sampai sejauh ini hal tersebut belum terbukti.
== Kemampuan ==
MySQL memiliki beberapa kapabilitas seperti:
# Unjuk kerja yang tinggi dalam memproses query sederhana, dalam arti dapat memproses lebih banyak SQL per satuan waktu.
# Memiliki lebih banyak tipe data seperti: signed/unsigned integer yang memiliki panjang data sebesar 1,2,3,4 dan 8 byte, FLOAT, DOUBLE, CHAR, VARCHAR, TEXT, BLOB, DATE, TIME, DATETIME, TIMESTAMP, YEAR, SET dan tipe ENUM.
# Mendukung field yang dijadikan Index, dengan maksimal 32 index dalam satu tabel.
# MYSQL memiliki beberapa lapisan keamanan, seperti ''subnetmask'', nama ''host'', dan izin akses user dengan sistem perijinan yang mendetail serta sandi/password terenkripsi.
# MySQL dapat melakukan koneksi dengan klien menggunakan protokol TCP/IP,Unix soket (UNIX),atau Named Pipes(NT).
# MySQL dapat digunakan oleh beberapa pengguna dalam waktu yang bersamaan tanpa mengalami masalah atau konflik
# MySQL memiliki fungsi dan operator secara penuh yang mendukung perintah ''select'' dan ''where'' dalam ''query''.
# MySQL memiliki struktur tabel yang lebih fleksibel dalam menangani ''ALTER TABLE'' dibandingkan DBMS lainnya.
# MySQL mampu menangani basis data dalam skala besar, dengan jumlah rekaman ([[records]]) lebih dari 50 juta dan 60 ribu tabel serta 5 miliar baris. Selain itu batas indeks yang dapat ditampung mencapai 32 indeks pada tiap tabelnya.
# Mendukung penuh terhadap kalimat SQL GROUP BY dan ORDER BY. Mendukung terhadap fungsi penuh ( COUNT(),COUNT(), DISTINCT() AVG(), STD(), SUM(), MAX() dan MIN() )
== Kelebihan dan kekurangan ==
Hal paling mendasar yang menjadikan MySQL pilihan utama sebagai database yang digunakan adalah karena MySQL tidak dipungut biaya dan lintas platform, sehingga lebih disukai para mahasiswa karena tidak membutuhkan biaya besar dalam membuat aplikasi serta tidak harus tergantung pada OS Windows ataupun Linux karena dapat dijalankan pada kedua OS tersebut dan beberapa OS lainnya. Tapi alasan tersebut tidaklah cukup untuk menjadikan MySQL sebagai RDBMS yang akan digunakan. Berikut keunggulan lain yang diberikan
=== Kelebihan ===
# Berlisensi GPL dan dapat dijalankan di berbagai platform seperti Windows, Linux, FreeBSD, Mac Os X Server, Solaris, Amiga, dan masih banyak lagi.
# Dapat diintegrasikan dengan beberapa bahasa Pemrograman seperti PHP, .Net, Java, Python, Perl yang merupakan bahasa pemrograman yang paling dominan di kalangan programmer.
# Mendukung ODBC untuk sistem operasi Windows sehingga bisa digunakan aplikasi yang berjalan diwindows.
# Bisa dijalankan pada spesifikasi hardware yang rendah karena lebih hemat resource memory (dibandingkan database lain) sehingga mudah digunakan untuk bahan pembelajaran.
# MySQL dapat mendeteksi pesan kesalahan pada klien dengan menggunakan lebih dari 20 bahasa meskipun bahasa indonesia belum termasuk didalamnya.
#
=== Kekurangan ===
# Banyak mengklaim{{Siapa}} kurang support terhadap pemrograman Visual/Desktop, sehingga sedikit yang menggunakan untuk aplikasi visual.
#
# Sangat diragukan dalam menangani data skala besar, karena ada beberapa opini{{Siapa}} yang pro dan kontra terhadap kemampuan MySQL terhadap pengolahan data yang besar.
== Antarmuka Pemrograman Aplikasi ==
Terdapat beberapa [[API]] (''Application Programming Interface'') tersedia yang memungkinkan aplikasi-aplikasi komputer yang ditulis dalam berbagai [[bahasa pemrograman]] untuk dapat mengakses basis data MySQL antara lain: [[bahasa pemrograman C]], [[C++]], [[C Sharp|C#]], [[bahasa pemrograman Eiffel]], [[bahasa pemrograman Smalltalk]], [[Java|bahasa pemrograman Java]], [[Lisp|bahasa pemrograman Lisp]], [[Perl]], [[PHP]], [[bahasa pemrograman Python]], [[Ruby]], [[REALbasic]] dan [[Tcl]]. Sebuah antarmuka [[ODBC]] memanggil [[MyODBC]] yang memungkinkan setiap bahasa pemrograman yang mendukung [[ODBC]] untuk berkomunikasi dengan basis data MySQL. Kebanyakan kode sumber MySQL dalam bahasa [[bahasa pemrograman C|ANSI C]].
== Penggunaan ==
MySQL sangat populer dalam [[aplikasi web]] seperti [[MediaWiki]] (perangkat lunak yang dipakai [[Wikipedia]] dan proyek-proyek sejenis) dan [[PHP-Nuke]] dan berfungsi sebagai komponen basis data dalam [[LAMP]]. Popularitas sebagai aplikasi web dikarenakan kedekatannya dengan popularitas [[PHP]], sehingga sering kali disebut sebagai ''Dynamic Duo''.
== Administrasi ==
Untuk melakukan administrasi dalam basis data MySQL, dapat menggunakan modul yang sudah termasuk yaitu ''[[Command line|command-line]]'' (perintah: <code>mysql</code> dan <code>mysqladmin</code>). Juga dapat diunduh dari situs MySQL yaitu sebuah modul berbasis grafik (''[[Graphical user interface|GUI]]''): ''[http://mysql.com/products/tools/administrator MySQL Administrator]'' dan ''[http://mysql.com/products/tools/query-browser MySQL Query Browser]''. Selain itu terdapat juga sebuah perangkat lunak gratis untuk administrasi basis data MySQL berbasis web yang sangat populer yaitu [[phpMyAdmin]]. Untuk perangkat lunak untuk administrasi basis data MySQL yang dijual secara komersial antara lain: MySQL front, Navicat dan EMS SQL Manager for MySQL. Untuk pengelolaan website di hosting, database MySQL dapat dikelola melalui phpMyAdmin.
== Komunitas MySQL di Indonesia ==
MySQL termasuk salah satu database utama yang digunakan di Indonesia terutama di kalangan developer PHP. Ini disebabkan native integration antara PHP dan MySQL serta banyaknya hosting yang menyertakan kedua produk tersebut karena bebas lisensi dan sudah terbukti tangguh dan efisien.
Website komunitas MySQL Indonesia yang terpisah dari komunitas PHP dapat Anda kunjungi di [http://groups.google.com/group/mysql-indonesia
== Sertifikasi MySQL ==
Oracle selaku pemilik MySQL menawarkan sertifikasi kompetensi di Oracle University, meliputi<ref>{{Cite web|title=MySQL :: MySQL Certification|url=https://www.mysql.com/certification/|website=www.mysql.com|access-date=2024-06-05}}</ref>:
* MySQL Database Administration: Oracle Certified Professional MySQL 8.0 Database Administrator, MySQL 2021 Certified Implementation Specialist, MySQL Heatwave Implementation Certified Associate Rel 1
* MySQL Developer: MySQL 8.0 Database Developer Oracle Certified Professional
== Lihat pula ==
* [[MariaDB]]
* [[Microsoft SQL Server]]
* [[PostgreSQL]]
* [[MySQLite]]
== Referensi ==
{{reflist}}
== Pranala luar ==
{{Commonscat}}
{{Wikibooks}}
* {{Official website|http://www.mysql.com/}}
* [http://www.oracle.com/us/products/mysql/index.html MySQL] at [[Oracle Corporation|Oracle]]
* {{en}} [http://mysqldatabaseadministration.blogspot.com/ MySQL Database Administration Blog]
* {{dmoz|/Computers/Software/Databases/MySQL/|MySQL}}
* {{id}} [http://mysql.phi-integration.com/ Tutorial MySQL Berbahasa Indonesia]
{{MySQL}}
{{Sun Microsystems}}
{{Oracle}}
{{Authority control}}
[[Kategori:Sistem manajemen basis data]]
[[Kategori:Sistem manajemen basis data sumber terbuka]]
|