Konten dihapus Konten ditambahkan
Tidak ada ringkasan suntingan
Tag: Suntingan visualeditor-wikitext
k Pranala luar: clean up
 
(13 revisi perantara oleh 9 pengguna tidak ditampilkan)
Baris 1:
{{untuk|nama kelompok lawak di Indonesia|SQL (lawak)}}
{{Infobox programming language
| name = SQL
| paradigm = [[Multi-paradigm programming language|Multi-paradigma]]
| year = 1974
| designer = [[Donald D. Chamberlin]]<br />[[Raymond F. Boyce]]
| developer = [[ISO]]/[[International Electrotechnical Commission|IEC]]
| latest_release_version = [[SQL:20112023]]
| latest_release_date = {{Start date and age|2023|06}}<ref>{{Cite web|last=|date=Juni 2023|title=ISO/IEC 9075-2:2023|url=https://www.iso.org/standard/76584.html|website=ISO.org|language=en|access-date=31 Agustus 2023}}</ref>
| latest_release_date = 2011
| turing-complete = No
| typing = [[Static typing|Statis]], [[strong typing|kuat]]
| implementations = [[List of relational database management systems|Beragam]]
| dialects = SQL-86, SQL-89, [[SQL-92]], [[SQL:1999]], [[SQL:2003]], [[SQL:2008]], [[SQL:2011]]
| influenced_by = [[Datalog]]
| influenced = [[Agena (programming language)|Agena]], [[Common Query Language|CQL]], [[Language Integrated Query|LINQ]], [[Windows PowerShell]]<ref name=ars>{{cite web|last=Paul|first=Ryan|title=A guided tour of the Microsoft Command Shell|url=http://arstechnica.com/business/news/2005/10/msh.ars/4|publisher=Ars Technica|accessdate=10 April 2011}}</ref>
| operating_system = [[Cross-platform]]
| website = {{cite web | url = http://www.iso.org/iso/catalogue_detail.htm?csnumber=45498 | title = ISO/IEC 9075-1:2008: Information technology – Database languages – SQL – Part 1: Framework (SQL/Framework) | postscript = <!-- Bot inserted parameter. Either remove it; or change its value to "." for the cite to end in a ".", as necessary. -->{{inconsistent citations}}}}
}}
{{Infobox file format
Baris 34:
| file_ext = .sql
}}
'''SQL''' ({{IPAc-en|audio=En-us-SQL.ogg|ˌ|ɛ|s|ˌ|k|juː|ˈ|ɛ|l}} ''S-Q-L'',<ref>{{cite book|last= Beaulieu|first = Alan|title=Learning SQL|url= https://archive.org/details/learningsql0000beau_p5d6|editor=Mary E Treseler|publisher=O'Reilly|location=Sebastapol, CA, USA|date=April 2009|edition= 2nd|isbn = 978-0-596-52083-0}}</ref> {{IPAc-en|ˈ|s|iː|k|w|əl}} "sequel"; '''Structured Query Language''')<ref name="chamberlin2001">{{cite web|url=https://conservancy.umn.edu/handle/11299/107215|last=Chamberlin|first=Donald D.|title=Oral history interview with Donald D. Chamberlin|date=2001-10-03|access-date=2020-01-14|quote=We changed the original name "SEQUEL" to SQL because we got a letter from somebody’s lawyer that said the name "SEQUEL" belonged to them. We shortened it to SQL, for Structured Query Language, and the product was known as SQL/DS.}}</ref> adalah sebuah [[Bahasa pemrograman|bahasa]] yang digunakan untuk mengakses [[data]] dalam [[basis data]] [[RDBMS|relasional]]. Bahasa ini secara ''[[de facto]]'' merupakan bahasa standar yang digunakan dalam manajemen basis data relasional. Saat ini hampir semua [[server basis data]] yang ada mendukung bahasa ini untuk melakukan manajemen datanya.
 
== Sejarah ==
Baris 49:
 
== Pemakaian dasar ==
Secara umum, SQL terdiri dari dua bahasa, yaitu ''[[Data Definition Language]]'' (DDL) dan ''[[Data Manipulation Language]]'' (DML). Implementasi DDL dan DML berbeda untuk tiap [[sistem manajemen basis data]] (SMBD),<ref>Troels Arvin, 2007-05-26, http://troels.arvin.dk/db/rdbms/ Comparison of different SQL implementations</ref>, namun secara umum implementasi tiap bahasa ini memiliki bentuk standar yang ditetapkan [[ANSI]]. Artikel ini akan menggunakan bentuk paling umum yang dapat digunakan pada kebanyakan SMBD.
=== Data Definition Language ===
DDL digunakan untuk mendefinisikan, mengubah, serta menghapus [[basis data]] dan objek-objek yang diperlukan dalam basis data, misalnya [[tabel]], [[view]], [[user]], dan sebagainya. Secara umum, DDL yang digunakan adalah <code>CREATE</code> untuk membuat objek baru, <code>USE</code> untuk menggunakan objek, <code>ALTER</code> untuk mengubah objek yang sudah ada, dan <code>DROP</code> untuk menghapus objek. DDL biasanya digunakan oleh [[administrator]] basis data dalam pembuatan sebuah [[program|aplikasi]] basis data.
Baris 55:
<code>CREATE</code> digunakan untuk membuat basis data maupun objek-objek basis data. SQL yang umum digunakan adalah:
 
<sourcesyntaxhighlight lang="mysql">CREATE DATABASE nama_basis_data</sourcesyntaxhighlight>
 
<code>CREATE DATABASE</code> membuat sebuah basis data baru.
 
<sourcesyntaxhighlight lang="mysql">CREATE TABLE nama_tabel</sourcesyntaxhighlight>
 
<code>CREATE TABLE</code> membuat tabel baru pada basis data yang sedang aktif. Secara umum, perintah ini memiliki bentuk
<sourcesyntaxhighlight lang="mysql">
CREATE TABLE [''nama_tabel'']
(
Baris 69:
...]
)
</syntaxhighlight>
</source>
atau
<sourcesyntaxhighlight lang="mysql">
CREATE TABLE [''nama_tabel'']
(
Baris 79:
[CONSTRAINT nama_field constraints]
)
</syntaxhighlight>
</source>
dengan:
 
Baris 91:
 
Contoh:
<sourcesyntaxhighlight lang="mysql">
CREATE TABLE user
(
Baris 98:
tanggal_lahir DATETIME
);
</syntaxhighlight>
</source>
akan membuat tabel <code>user</code> seperti berikut:
{| class="wikitable"
Baris 117:
==== <code>SELECT</code> ====
 
<code>SELECT</code> adalah perintah yang paling sering digunakan pada SQL, sehingga kadang-kadang istilah ''query'' dirujukkan pada perintah <code>SELECT</code>.<code>SELECT</code> digunakan untuk menampilkan data dari satu atau lebih tabel, biasanya dalam sebuah basis data yang sama. Secara umum, perintah <code>SELECT</code> memiliki bentuk lengkap:<sourcesyntaxhighlight lang="mysql">
( QUERY BUDIN ) Cilegon.
SELECT [nama_tabel|alias.]nama_field1 [AS alias1] [, nama_field2, ...]
Baris 126:
[GROUP BY nama_field1[, nama_field2, ...]]
[HAVING ''kondisi_aggregat'']
</syntaxhighlight>
</source>
dengan:
* ''kondisi'' adalah syarat yang harus dipenuhi suatu data agar ditampilkan.
Baris 178:
Contoh 1:
Tampilkan seluruh data.
<sourcesyntaxhighlight lang="mysql">
SELECT *
FROM user
</syntaxhighlight>
</source>
Contoh 2:
Tampilkan pengguna yang tidak pernah bertransaksi.
<sourcesyntaxhighlight lang="mysql">
SELECT *
FROM user
WHERE total_transaksi = 0
</syntaxhighlight>
</source>
Contoh 3:
Tampilkan username pengguna yang bertransaksi kurang dari 10 dan nilainya lebih dari 1.000.
<sourcesyntaxhighlight lang="mysql">
SELECT username
FROM user
WHERE jml_transakai < 10 AND total_transaksi > 1000
</syntaxhighlight>
</source>
Contoh 4:
Tampilkan total nominal transaksi yang sudah terjadi.
<sourcesyntaxhighlight lang="mysql">
SELECT SUM(total_transaksi) AS total_nominal_transaksi
FROM user
</syntaxhighlight>
</source>
Contoh 5:
Tampilkan seluruh data diurutkan berdasarkan jumlah transaksi terbesar ke terkecil.
<sourcesyntaxhighlight lang="mysql">
SELECT *
FROM user
ORDER BY jml_transaksi DESC
</syntaxhighlight>
</source>
===== Fungsi aggregat =====
Beberapa SMBD memiliki fungsi aggregat, yaitu fungsi-fungsi khusus yang melibatkan sekelompok data (aggregat). Secara umum fungsi aggregat adalah:
Baris 223:
 
Tampilkan username pengguna yang memiliki jumlah transaksi terbesar.
<sourcesyntaxhighlight lang="mysql">
SELECT username
FROM user
Baris 231:
FROM user
)
</syntaxhighlight>
</source>
==== <code>INSERT</code> ====
Untuk menyimpan data dalam tabel digunakan sintaks:
<sourcesyntaxhighlight lang="mysql">
INSERT INTO [NAMA_TABLE] ([DAFTAR_FIELD]) VALUES ([DAFTAR_NILAI])
</syntaxhighlight>
</source>
Contoh:
<sourcesyntaxhighlight lang="mysql">
INSERT INTO TEST (NAMA, ALAMAT, PASSWORD) VALUES ('test', 'alamat', 'pass');
</syntaxhighlight>
</source>
==== <code>UPDATE</code> ====
Untuk mengubah data menggunakan sintax:
<sourcesyntaxhighlight lang="mysql">
UPDATE [NAMA_TABLE] SET [NAMA_KOLOM]=[NILAI] WHERE [KONDISI]
</syntaxhighlight>
</source>
Contoh:
<sourcesyntaxhighlight lang="mysql">
UPDATE Msuser set password="123456" where username="abc"
</syntaxhighlight>
</source>
==== <code>DELETE</code> ====
 
Untuk menghapus data dipergunakan sintaks:
<sourcesyntaxhighlight lang="mysql">
DELETE FROM [nama_table] Where [KONDISI]
</syntaxhighlight>
</source>
Contoh:
<sourcesyntaxhighlight lang="mysql">
DELETE FROM TEST WHERE NAMA='test';
</syntaxhighlight>
</source>
 
== Catatan ==
Baris 268:
 
== Pranala luar ==
* {{en}} [http://www.sql.org/ SQL Org]
* {{en}} [http://www.1keydata.com/sql/sql.html SQL Tutorial]
* {{en}} Mike Chapple, [http://databases.about.com/od/sql/a/sqlfundamentals.htm ''SQL Fundamentals''] {{Webarchive|url=https://web.archive.org/web/20090222225300/http://databases.about.com/od/sql/a/sqlfundamentals.htm |date=2009-02-22 }}
* {{en}} MySQL AB, [http://dev.mysql.com/doc/refman/5.0/en/index.html MySQL 5.0 Reference Manual]
* {{id}}Buku Gratis MySQL 5: Dari Pemula Hingga Mahir, [http://achmatim.net/2010/01/30/buku-gratis-mysql-5-dari-pemula-hingga-mahir/ Buku Gratis MySQL 5]
 
{{Daftar bahasa pemrograman}}
{{Authority control}}
 
[[Kategori:SQL| ]]
[[Kategori:Bahasa pemrograman]]
[[Kategori:ArtikelBasis kelas awal bertopik teknologi informasidata]]