Tutorial Membuat Tabel MySQL Dengan PHP


Tutorial ini akan membahas tentang bagaimana membuat antar muka untuk membuat tabel di database mysql menggunakan kode php. Jika Anda pernah membuat tabel menggunakan aplikasi phpMyAdmin, maka hal ini akan mirip dengan apa yang akan di praktikan dalam tutorial ini, hanya saja disini kita akan membuat versi membuat tabel dengan cara kita sendiri dimana kita akan membuat susunan kode/script php yang bisa melakukan operasi pembuatan tabel pada database mysql.

DATABASE
Sebelum membuat tabel pada database, maka terlebih dahulu Anda membuat koneksi script untuk melakukan koneksi database mysql

koneksi.php


<?php
define("DB_HOST", "localhost");
define("DB_USER","root");
define("DB_PASS","");

$koneksi= new mysqli(DB_HOST, DB_USER, DB_PASS);
if($koneksi==false):
 die("Gagal melakukan koneksi".$koneksi->connect_error());
endif;

?>


MEMBUAT DATABASE

Selanjutnya sebelum membuat tabel, Anda perlu membuat antar muka untuk membuat database terlebih dahulu. Anda bisa menggunakan paramter query CREATE DATABASE IF NOT EXISTS seperti yang di contohkan pada script membuat database dibawah ini :

create_db.php


<?php
require_once('koneksi.php');
$nama_database_err="";
if($_SERVER['REQUEST_METHOD']=='POST'){
 if(empty($_POST['nama_database'])){
  $nama_database_err='Nama database tidak boleh kosong';
 }else{
  //cek apakah nama database tersebut sudah ada sebelumnya
  $cek_db=$koneksi->select_db($_POST['nama_database']);
  if($cek_db){
   $nama_database_err="Database ".$_POST['nama_database']." sudah ada !";   
  }else{
   $nama_database=$koneksi->escape_string($_POST['nama_database']);
  }
 }
 if(empty($nama_database_err)){
  $sql=sprintf("CREATE DATABASE IF NOT EXISTS %s",$nama_database);
  if($koneksi->query($sql)):
   echo "Database berhasil dibuat";
  else:
   echo "Database gagal dibuat";
  endif;
 }
}

?>
<!DOCTYPE html>
<html>
<head>
 <title>Buat Database</title>
 <link href="../style/bootstrap.min.css" rel="stylesheet">
 
</head>
<body>
<div class="container">
 <h1>Buat Database</h1>
 <hr>
 <div class="row">
  <form action="<?php echo htmlspecialchars($_SERVER['PHP_SELF']); ?>" method="post">

  
    <div class="form-group">
     <label>Nama Database :</label>
     <input class="form-control" type="text" name="nama_database" id="nama_database" />
     <span><?php echo $nama_database_err; ?></span>
    </div>
    <div class="form-group">
     <input class="btn btn-md btn-primary" type="submit" name="buat" value="Buat" />
    </div>  
  </form>
  <a href="list_db.php">Lihat Database</a>
 </div>
</div>
</body>
</html>


antar muka untuk membuat database
Antar muka untuk membuat database : root93.co.id
MEMBUAT TABEL

Proses selanjutnya adalah bagian membuat tabel, tapi sebelumnya Anda perlu mendefinisikan nama database yang akan digunakan untuk menampung tabel yang akan dibuat. Jadi Anda perlu membuat script untuk memilih database yang akan digunakan seperti yang di contohkan pada script dibawah ini :

select_db.php


<?php
require_once('koneksi.php');

$select_db=$koneksi->select_db("latihan1");
if(!$select_db){
 echo "Gagal memilih database";
}
?>


Selanjutnya membuat antar muka untuk membuat tabel, ini terdiri dari antar muka untuk menampung nama tabel dan jumlah kolom yang akan digunakan, kemudian selanjutnya kita perlu menampilkan antar muka jumlah inputan kolom sesuai yang di inputkan oleh user beserta tipe dan panjang/length datanya.

create_tb.php


<?php
 require_once('koneksi.php');
 require_once('select_db.php');
 /*
 Bagian ini proses untuk menyimpan nama dan panjang kolom

 */
 $nama_tbl_err = $pjg_kolom_err = $nama_tbl = $pjg_kolom ="";
 if($_SERVER['REQUEST_METHOD']=='POST'){
  if(empty($_POST['nama_tbl'])){
   $nama_tbl_err="Nama tabel masih kosong";
  }else{
   $nama_tbl=$_POST['nama_tbl'];
  }
  if(empty($_POST['pjg_kolom'])){
   $pjg_kolom_err="Panjang kolom tidak boleh kosong";
  }elseif(!is_numeric($_POST['pjg_kolom'])){
   $pjg_kolom_err="Panjang kolom harus berupa angka";
  
  }else{
   $pjg_kolom=$_POST['pjg_kolom'];
  }
  if(empty($nama_tbl_err) && empty($pjg_kolom_err)){
   $nama_tabel=$nama_tbl;
   $panjang_kolom=$pjg_kolom;
  }
 }
?>

<!DOCTYPE html>
<html>
<head>
 <title>Membuat Tabel</title>
 <link href="../style/bootstrap.min.css" rel="stylesheet">
</head>
<body>
 <div class="container">
  <h1>Buat Tabel</h1>
  <hr>
 <div class="row">
  <form action="<?php echo $_SERVER['PHP_SELF'];?>" method="post">
   <div class="row"> 
    <div class="col-6">
     <div class="form-group">
      <label>Nama Tabel</label>
      <input class="form-control" type="text" name="nama_tbl" id="nama_tbl" value="<?php echo $nama_tbl; ?>">
      <span><?php echo $nama_tbl_err; ?></span>
     </div>
    </div>
    <div class="col-4">
     <div class="form-group">
      <label>Jumlah kolom</label>
      <input class="form-control" type="text" name="pjg_kolom" id="pjg_kolom" value="<?php echo $pjg_kolom; ?>" />
      <span><?php echo $pjg_kolom_err; ?></span>     
     </div>
    </div>
    <div class="col-4">
     <input class="btn btn-md btn-primary" type="submit" name="kirim" id="kirim" value="kirim" />
    </div>
   </div>
  </form>

  <?php
  /*jika kondisi $nama_tabel dan $panjang_kolom terpenuhi atau tidak kosong, maka jalankan perintah berikutnya
  lakukan perulangan berdasakrkan panjang kolom yang dimiinta oleh user
  */
  if(!empty($nama_tabel)&& ($panjang_kolom)){
   $tabel = $nama_kolom_err= $panjang_kolom_err ="";
   /*Validasi tabel
   Saat terjadi proses simpan pada tabel. Kondisi ini akan terpenuhi jika $nama_tabel dan $panjang kolom terpenuhi
   */
   if(isset($_POST['ciptakan_tabel'])){
    $kol="";
    for($i=1; $i<=$panjang_kolom; $i++){
     $nmkol="nama_kolom".$i;
     $tipe="tipe_data".$i;
     $pjg="length".$i;
     $nul="kosong".$i;
     if($nul!="NULL"){
      $kos="NOT NULL";
     }
     //validasi nama kolom dan length kolom
     if(empty(trim($_POST[$nmkol]))){
      $nama_kolom_err="Nama kolom tidak boleh kosong";
     }elseif(empty($_POST[$pjg])){
      $panjang_kolom_err="Panjang kolom tidak boleh kosong";
     }else{ 
      /*$kol ini berisi format nama kolom tipe dan panjang serta atribut not null
      Contoh query nantinya akan berisi format berikut : nama_kolom INT(13) NOT NULL, dst
      */   
      $kol.=$_POST[$nmkol]." ".$_POST[$tipe]." (".$_POST[$pjg].") ".$kos.",";

     }
    //akhir perulangan for 
    }
    //jika nama klom dan length kolom tidak kosong, maka eksekusi perintah berikutnya
    if(empty($nama_kolom_err) && empty($panjang_kolom_err)){
     /*query untuk membuat tabel
     jadi querynya kurang lebih akan memiliki hasil CREATE TABLE nama_tabel (nama_kolom INT(13) NOT NULL,
      dan seterusnya dan memberi primary key pada paramter nama_kolom1
     )
     */
     $per=sprintf("CREATE TABLE %s(%s%s)",$_POST['nama_tabel'],$kol,"PRIMARY KEY(".$_POST['nama_kolom1'].")");
     if(!$koneksi->query($per)){
      $tabel='<div class="alert alert-danger">Tabel gagal dibuat</div>';
     }else{
      $tabel='<div class="alert alert-success">Tabel berhasil dibuat</div>';
     }
    }

    //query test
    //CREATE TABLE `latihan1`.`uji` ( `id` INT(13) NOT NULL AUTO_INCREMENT , `nama` VARCHAR(30) NOT NULL , PRIMARY KEY (`id`)) ENGINE = InnoDB;
   }
  /*jika kondisi $nama_tabel dan $panjang_kolom terpenuhi atau tidak kosong, maka jalankan perintah berikutnya
  lakukan perulangan berdasakrkan panjang kolom yang dimiinta oleh user. Formulir ini akan ditampilkan
  */
   echo '
  <form action="'.$_SERVER['PHP_SELF'].'" method="post">
   <input type="hidden" name="nama_tbl" id="nama_tbl" value="'.$nama_tabel.'" />
   <input type="hidden" name="pjg_kolom" id="pjg_kolom" value="'.$panjang_kolom.'" />
   <div class="row">
    '.$tabel.'
    <table class="table table-bordered">
     <tr>
      <th colspan="4">Tabel '.$nama_tabel.'<br/><span>'.$nama_kolom_err.''.$panjang_kolom_err.'</th>
     </tr>
     <tr>
      <th>Nama Kolom</th>
      <th>Tipe Data</th>
      <th>Length</th>
      <th>Kosong</>
     </tr>

     ';
     //lakukan perulangan sesuai dengan panjang kolom
     for($k=1; $k<=$panjang_kolom; $k++){
      $nama_kolom="nama_kolom".$k;
      $tipe_data="tipe_data".$k;
      $length="length".$k;
      $kosong="kosong".$k;
      echo '
      <tr>
       <td>
       <input class="form-control" type="text" name="'.$nama_kolom.'" id="'.$nama_kolom.'"  />
       
       
       </td>
       <td>
       <select class="form-control" name="'.$tipe_data.'" id="'.$tipe_data.'">
        <option value="char">char</option>
        <option value="varchar">varchar</option>
        <option value="text">text</option>
        <option value="int">int</option>
        <option value="bigint">bigint</option>
        <option value="longtext">longtext</option>
        <option value="set">set</option>
        <option value="enum">enum</option>
        <option value="float">float</option>
       </select>
       </td>

       <td><input class="form-control" type="text" name="'.$length.'" id="'.$length.'" /></td>
       <td><input type="checkbox" name="'.$kosong.'" id="'.$kosong.'" value="NULL"/></td>       
       
      </tr>     

      ';
     }

   echo'
      <tr>
      <input type="hidden" name="nama_tabel" id="nama_tabel" value="'.$nama_tabel.'" />
      <input type="hidden" name="'.$panjang_kolom.'" id="'.$panjang_kolom.'" value="'.$panjang_kolom.'" />

      <td colspan="5"><input class="btn btn-md btn-primary" type="submit" name="ciptakan_tabel" id="ciptakan_tabel" value="Simpan" /></td>
      </tr>  
   </div>
   </form>
   ';
  }

  ?>

 </div>
</div>
</body>
</html>


antar muka untuk membuat tabel
Antar muka untuk membuat tabel - blog root93
ALUR PEMBUATAN TABEL

Pada script create_tb.php saya sudah memberi tanda keterangan bagaimana proses terjadinya pembuatan tabel. Disini saya akan memberikan keterangan bagaimana antar muka diatas bekerja membuat tabel pada database mysql.
  1. Saat user memasukan nama tabel beserta jumlah kolomnya, maka pada sisi kanan akan muncul tabel dengan jumlah kolom yang sesuai di inputkan oleh user. Ini terdiri dari 4 kategori nama kolom, tipe data, length atau panjang datanya dan atribut null/kosong. Saat user memasukan nama tabel dan jumlah kolom, disana akan ada validasi apakah user sudah memasukan nama tabel dan jumlah kolom yang di inginkannya, jika belum maka tabel kanan tidak akan ditampilkan
  2. Selanjutnya ketika kondisi pertama (1) terpenuhi maka akan ditampilkan tabel pada sisi kanan, itu bukan hanya sekedar tabel, tapi juga merupakan form action yang nantinya bertugas untuk menginsertkan data tabel ke database mysql. Paramater nama tabel dan jumlah kolom akan di proses pada bagian action ini, script akan melakukan perulangan for sama seperti ketika menampilkan tabel pada sisi kanan point (1). Perulangan for yang kedua ini akan menampung nama – nama kolom, tipe, panjang dan null/not null sesuai dengan jumlah kolom yang di inputkan, nilai tersebut akan dijadikan dan atau disimpan didalam satu variabel $kol yang nantinya akan dijalankan bersama parameter query CREATE TABLE
  3. Sebenarnya disini tidak dibuat parameter untuk mengecek apakah tabel sudah dibuat sebelumnya atau tidak, karena secara otomatis mysql akan mereturn nilai false jika user mencoba menambahkan nama tabel yang sudah ada sebelumnya di database


3 Responses to "Tutorial Membuat Tabel MySQL Dengan PHP"

  1. Aduh, puyeng aku kalo masalah php, MySQL, dll buat hosting kang. Apalagi buat tabel MySQL, sedangkan MySQL itu apa aku juga tidak paham.😂

    ReplyDelete
  2. Membuat tabel di database mysql hampir mirip seperti membuat tabel di aplikasi phpMyadmin, hanya saja dengan kode buatan sendiri yang lebih sederhana dan mudah dipraktekan.
    Maaf saya OOT, saya pernah mengenal seseorang dari jurusan multimedia yang kemudian ingin belajar programming.
    Sepertinya multimedia cukup akrab dengan PHP ya Kang?

    ReplyDelete
  3. kalau share kode sql nya bsa mantap lg nih mas. supaya cepet buat tabelnya hehe

    ReplyDelete

Komentar yang Anda kirim akan terlebih dahulu di moderasi oleh Admin