> For the complete documentation index, see [llms.txt](https://learn.devlabss.my.id/llms.txt). Markdown versions of documentation pages are available by appending `.md` to page URLs; this page is available as [Markdown](https://learn.devlabss.my.id/php/bab-8-php-and-mysql-pdo/8.1-koneksi-database.md).

# 8.1 Koneksi Database

PDO memberi cara yang lebih rapi dan aman untuk terhubung ke database.

Bagian ini menjelaskan parameter koneksi dan struktur dasar penggunaan PDO.

### Video pengantar

Tonton video ini untuk mendapat gambaran awal sebelum lanjut ke materi inti.

{% embed url="<https://youtu.be/gvkr2V-JULE?si=PM9cAgJiaBcF1ohT>" %}

### Tujuan belajar

Setelah mempelajari bagian ini, Anda diharapkan bisa:

* memahami fungsi koneksi database
* mengenal komponen dasar koneksi PDO
* membuat koneksi sederhana dari PHP ke MySQL

### Kenapa database dibutuhkan

Sampai bab sebelumnya, data masih ditulis langsung di dalam kode.

Cara itu cocok untuk latihan dasar. Namun, aplikasi nyata butuh tempat penyimpanan yang bisa menampung banyak data dan bisa diubah kapan saja.

Database dipakai untuk menyimpan data seperti:

* data siswa
* akun pengguna
* daftar produk

### Kenapa memakai PDO

PDO adalah cara modern di PHP untuk terhubung ke database.

PDO dipilih karena:

* lebih rapi
* mendukung prepared statement
* cocok untuk belajar praktik yang lebih aman

### Komponen dasar koneksi

Saat membuat koneksi, biasanya Anda menyiapkan:

* nama host
* nama database
* username database
* password database

### Contoh koneksi dasar

```php
<?php
$host = "localhost";
$db   = "sekolah";
$user = "root";
$pass = "";

try {
    $pdo = new PDO("mysql:host=$host;dbname=$db", $user, $pass);
    $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    echo "Koneksi berhasil";
} catch (PDOException $e) {
    echo "Koneksi gagal: " . $e->getMessage();
}
?>
```

### Penjelasan singkat

Pada contoh itu:

* `new PDO(...)` dipakai untuk membuat koneksi
* `try` dipakai untuk mencoba proses koneksi
* `catch` dipakai untuk menangkap error jika koneksi gagal

### Kenapa `try` dan `catch` dipakai

Koneksi database bisa gagal karena banyak hal.

Misalnya:

* nama database salah
* username salah
* server database belum aktif

Dengan `try` dan `catch`, program bisa memberi pesan yang lebih jelas saat gagal.

### Tips struktur file

Saat proyek mulai lebih besar, koneksi database sebaiknya dipisah ke file sendiri.

Contohnya, buat satu file khusus koneksi lalu panggil kembali saat dibutuhkan.

Kebiasaan ini membantu kode lebih rapi dan mudah dirawat.

### Kesalahan umum

* nama database salah
* server database belum berjalan
* lupa memakai `try` dan `catch`
* koneksi ditulis berulang di banyak file

### Latihan singkat

Coba lakukan hal berikut:

1. siapkan satu database latihan
2. buat koneksi dengan PDO
3. tampilkan pesan berhasil atau gagal

### Poin evaluasi bab 8.1.

Pastikan Anda sudah memahami poin berikut:

* Saya paham fungsi koneksi database.
* Saya tahu komponen dasar koneksi PDO.
* Saya bisa membaca contoh koneksi sederhana.
* Saya tahu beberapa penyebab umum koneksi gagal.

Jika semua sudah jelas, lanjut ke [8.2 Menampilkan Data (Read)](/php/bab-8-php-and-mysql-pdo/8.2-menampilkan-data-read.md).


---

# Agent Instructions
This documentation is published with GitBook. GitBook is the documentation platform designed so that both humans and AI agents can read, navigate, and reason over technical content effectively. Learn more at gitbook.com.

## Querying This Documentation
If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://learn.devlabss.my.id/php/bab-8-php-and-mysql-pdo/8.1-koneksi-database.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
