Untuk bermain-main dengan database pada laravel, sebenarnya ada 2 cara yang umum digunakan. yaitu kita bisa menggunakan Query Builder dan Eloquent.
Keduanya merupakan fitur yang sudah disediakan pada laravel. sehingga kita bisa lebih mudah dalam membuat CRUD pada laravel.
Tetapi pada sub judul ini kita akan belajar membuat CRUD dengan menggunakan Query Builder pada laravel.
Untuk tutorial membuat CRUD menggunakan Eloquent pada laravel akan kita bahas pada tutorial laravel selanjutnya.
Membuat CRUD Pada Laravel Dengan Query Builder
Untuk pembahasan tutorial membuat CRUD dengan laravel, akan kita awali dengan cara membuat CRUD menggunakan query builder dari laravel.
Jika teman-teman ingin membaca dokumentasi tentang cara penggunaan query builder untuk mengolah data pada database dengan laravel, teman-teman bisa juga membaca nya di sini.
Sebelumnya saya jelaskan dulu apa itu query builder. Query Builder bisa kita anggap sebagai fitur untuk menjalankan query database. jadi di sini laravel telah membuat fungsi-fungsi untuk menjalankan query database. misalnya untuk memilih mau menampilkan data pada table apa, kita bisa langsung saja menggunakan fungsi table() pada laravel.
Begitu juga jika kita ingin menampilkan data yang lebih spesifik seperti misalnya kita ingin menampilkan data yang memiliki kriteria tertentu misalnya menampilkan data yang id nya 5. maka kita tinggal menggunakan fungsi where( βidβ , βid_nya_isi_di_siniβ ) saja setelah memilih nama tabel nya.
Jadi penulisan query database jadi lebih singkat dan efisien.
Tidak hanya cuma bisa memilih table dan menggunakan fungsi where(). ada juga fungsi lainnya seperti penggunaan JOIN, DISTINCT dan lain-lain.
Pokok nya udah lengkap. teman-teman bisa lihat di sini apa saja yang bisa kita lakukan dengan query builder nya si laravel.
Oke langsung saja kita mulai membuat CRUD Dengan Laravel. kita mulai dulu dengan melakukan konfigurasi database.
Pengaturan Database Pada Laravel
Contoh CRUD yang akan kita buat di sini adalah CRUD untuk data pegawai. jadi di sini kita akan membuat fungsi sebagai berikut :
- Menampilkan data dari database dengan laravel
- Menginput data ke database dengan laravel
- Mengupdate atau mengubah data pada database dengan laravel
- Menghapus data dari database dengan laravel
Karena kita akan berurusan dengan database. maka sekarang kita akan melakukan konfigurasi database dulu di laravel.
Silahkan teman-teman baca juga tutorial sebelumnya tentang konfigurasi pengaturan dasar pada laravel.
Seperti yang sudah dijelaskan sebelumnya, untuk mengatur database pada laravel kita bisa mengaturnya pada file .env. letaknya di direktori paling luar. jika tidak ada file .env di project laravel teman-teman, silahkan atur koneksi database nya di belajar_laravel/config/database.php.
Jika teman-teman mengikuti tutorial laravel di malasngoding.com dari bagian ke 1, nama project laravel kita kita buat dengan nama βbelajar_laravelβ.
Perhatikan file .env pada gambar di atas.
Silahkan teman-teman sesuaikan nama database yang akan digunakan, username dan password mysql nya.
BACA JUGA : Tutorial CRUD Dengan PHP dan MySQLi
Oke jika sudah, berarti konfigurasi databasenya selesai, cukup mudah.
Selanjutnya kita lanjutkan dengan mempersiapkan database dan tabel yang kita butuhkan.
Mempersiapkan Database dan Tabel Pegawai
Silahkan teman-teman buat database dengan nama yang sesuai dengan nama database yang sudah teman-teman tulis tadi pada file .env. pada contoh ini saya membuat database dengan nama βbelajar_laravelβ.
Dan buat table dengan nama βpegawaiβ. di sini kita membuat table pegawai dengan 5 column. yaitu pegawai_id, pegawai_nama, pegawai_jabatan, pegawai_umur dan pegawai_alamat.
pegawai_id | int ( auto increment ) |
pegawai_nama | varchar ( 50 ) |
pegawai_jabatan | varchar (20 ) |
pegawai_umur | int |
pegawai_alamat | text |
Lebih detailnya bisa teman-teman lihat pada gambar berikut.
Klik save atau simpan, maka proses persiapan database dan tabel selesai.
Selanjutnya kita lanjutkan dengan menampilkan data dari database menggunakan laravel.
Menampilkan Data Dari Database Dengan Laravel
Sebelum melangkah lebih jauh untuk cara menampilkan data dari databased dengan laravel. pastikan teman-teman sudah memiliki beberapa data di tabel admin. agar ada data yang bisa kita oleh. di sini saya sudah menginput beberapa data ke tabel pegawai. silahkan teman-teman input beberapa data pegawai terlebih dulu.
Setelah kita memiliki beberapa data untuk ditampilkan. maka sekarang kita mulai dengan membuat route untuk menampilkan data pegawai.
Buat route baru dengan alamat β/pegawaiβ.
belajar_laravel/routes/web.php
1
2
|
//route CRUD
Route::get(‘/pegawai’,‘PegawaiController@index’);
|
di sini kita memerintahkan untuk menjalankan method index() pada controller PegawaiController pada saat route β/pegawaiβ di akses.
Selanjutnya buat controller PegawaiController.php, karena kita belum mempunyai controller dengan nama PegawaiController.php.
Silahkan teman-teman baca lagi cara membuat controller di laravel. karena sudah dijelaskan juga sebelumnya.
Disini saya membuat controller menggunakan php artisan.
1
|
php artisan make:controller PegawaiController
|
Karena sebelumnya pada route β/pegawaiβ kita memerintahkan untuk menjalankan method index(). maka pada PegawaiController.php ini kita akan membuat metho index().
Dan karena kita akan menggunakan query builder laravel, maka kita wajib menambahkan perintah berikut pada bagian paling atas.
1
|
use Illuminate\Support\Facades\DB;
|
Sehingga keseluruhan isi dari controller PegawaiController.php akan menjadi seperti berikut.
belajar_laravel/app/Http/Controllers/PegawaiController.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;
class PegawaiController extends Controller
{
public function index()
{
// mengambil data dari table pegawai
$pegawai = DB::table(‘pegawai’)->get();
// mengirim data pegawai ke view index
return view(‘index’,[‘pegawai’ => $pegawai]);
}
}
|
Perhatikan pada fungsi index yang kita buat dalam controller PegawaiController.php di atas.
di sana kita mengambil data dari table βpegawaiβ hanya dengan perintah yang sangat pendek. yaitu
1
2
|
// mengirim data pegawai ke view index
$pegawai = DB::table(‘pegawai’)->get();
|
Dengan fungsi table() kita menentukan nama table yang ingin di pilih. fungsi get() berguna untuk mengampil data dari table yang di pilih.
Sehingga data yang diambil akan disimpan dalam variabel $pegawai.
Jadi intinya fungsi di atas itu seperti kita menampilkan data dari database dengan query mysql biasa seperti β SELECT * FROM pegawai β.
Selanjut nya kita passing atau kita kirim datanya ke view agar ditampilkan.
1
2
|
// mengirim data pegawai ke view index
return view(‘index’,[‘pegawai’ => $pegawai]);
|
Silahkan baca tutorial sebelumnya tentang cara mempassing data dari controller ke view laravel.
Karena kita belum punya view index. maka sekarang kita buat dulu view nya dengan nama index.blade.php.
belajar_laravel/resources/views/index.blade.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
<!DOCTYPE html>
<html>
<head>
<title>Tutorial Membuat CRUD Pada Laravel – www.malasngoding.com</title>
</head>
<body>
<h2>www.malasngoding.com</h2>
<h3>Data Pegawai</h3>
<a href=“/pegawai/tambah”> + Tambah Pegawai Baru</a>
<br/>
<br/>
<table border=“1”>
<tr>
<th>Nama</th>
<th>Jabatan</th>
<th>Umur</th>
<th>Alamat</th>
<th>Opsi</th>
</tr>
@foreach($pegawai as $p)
<tr>
<td>{{ $p–>pegawai_nama }}</td>
<td>{{ $p–>pegawai_jabatan }}</td>
<td>{{ $p–>pegawai_umur }}</td>
<td>{{ $p–>pegawai_alamat }}</td>
<td>
<a href=“/pegawai/edit/{{ $p->pegawai_id }}”>Edit</a>
|
<a href=“/pegawai/hapus/{{ $p->pegawai_id }}”>Hapus</a>
</td>
</tr>
@endforeach
</table>
</body>
</html>
|
Oke, coba teman-teman perhatikan pada view index.blade.php di atas. sebelumnya, pada controller data yang kita ambil dari table pegawai kita simpan dalam variabel $pegawai. kemudian kita passing ke view.
nah, pada view tinggal langsung kita tampilkan dalam perulangan foreach().
1
2
3
4
5
6
7
8
9
10
11
12
13
|
@foreach($pegawai as $p)
<tr>
<td>{{ $p–>pegawai_nama }}</td>
<td>{{ $p–>pegawai_jabatan }}</td>
<td>{{ $p–>pegawai_umur }}</td>
<td>{{ $p–>pegawai_alamat }}</td>
<td>
<a href=“/pegawai/edit/{{ $p->pegawai_id }}”>Edit</a>
|
<a href=“/pegawai/hapus/{{ $p->pegawai_id }}”>Hapus</a>
</td>
</tr>
@endforeach
|
Kenapa penulisan fungsi foreach() nya @foreach() sudah dijelaskan juga pada tutorial laravel sebelumnya.
dan sekarang coba kita lihat hasilnya. silahkan akses route β/pegawaiβ.
Sampai di sini kita telah berhasil menampilkan data pegawai dari database pada laravel.
Oke sekian dulu tutorial membuat CRUD Dengan Laravel.
Pada Part Selanjutnya kita akan melanjutkan tutorial membuat CRUD dengan Laravel ini dengan membuat proses input data ke database dengan laravel.
Sampai jumpa di tutorial selanjutnya.