Hướng dẫn tạo database php

Trước khi làm một dự án ban phải phân tích và thiết kế CSDL dựa vào yêu cầu của khách hàng nên có lẽ bài này là hơi dư thừa, nhưng đôi lúc bạn cũng cần tạo database bằng code PHP đấy. Điển hình nhất là WordPress, khi bạn cài đặt lần đầu tiên nó sẽ tự động tạo ra database và table để tương thích với hệ thống CMS của nó.

Hướng dẫn tạo database php

Hướng dẫn tạo database php

Bài viết này được đăng tại freetuts.net, không được copy dưới mọi hình thức.

1. Tạo database bằng code PHP

Trước khi tạo database thì ban phải kết nối CSDL trước, sau đó viết câu truy vấn tạo Database và thực thi câu truy vấn đó bằng PHP.

Sử dụng MySQLi Object-oriented:

// Tạo kết nối
$conn = new mysqli('localhost', 'root', 'vertrigo');

// Nếu kết nối thất bại
if ($conn->connect_error) {
    die("Kết nối thất bại: " . $conn->connect_error);
} 

// Lệnh tạo database
$sql = "CREATE DATABASE FreettusDemo";

// Thực thi câu truy vấn
if ($conn->query($sql) === TRUE) {
    echo "Tạo database thành công";
} else {
    echo "Tạo database thất bại: " . $conn->error;
}

// Tạo xong thì ngắt kết nối
$conn->close();

Lưu ý: Khi bạn sử dụng lệnh tạo database thì bạn chỉ kết nối vào MySQL và không được chọn database, nghĩa là bạn chỉ được phép truyền vào ba tham số host, username và password. Trường hợp bạn có sử dụng port thì bạn phải truyền tham số port vào, nhưng tham số tên database thì bạn truyền giá trị rỗng mysqli("localhost", "username", "password", "", port).

Sử dụng MySQLi Procedural:

// Tạo kết nối
$conn = mysqli_connect('localhost', 'root', 'vertrigo');

// Nếu kết nối thất bại
if (!$conn) {
    die("Kết nối thất bại: " . mysqli_connect_error());
}

// Lệnh tạo database
$sql = "CREATE DATABASE FreettusDemo";

// Thực thi câu truy vấn
if (mysqli_query($conn, $sql)) {
    echo "Tạo database thành công";
} else {
    echo "Tạo database thất bại: " . mysqli_error($conn);
}

// Tạo xong thì ngắt kết nối
mysqli_close($conn);

Sử dụng PDO:

try {
    // Chuỗi kết nối
    $conn = new PDO("mysql:host=localhost", 'root', 'vertrigo');
    
    // Thiết lập chế độ exception
    $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    
    // Câu truy vấn
    $sql = "CREATE DATABASE FreetutsDemo";
    
    // Thực thi câu truy vấn
    $conn->exec($sql);
    
    // Thông báo thành công
    echo "Tạo database thành công";
}
catch(PDOException $e)
{
    echo $e->getMessage();
}

// Ngắt kết nối
$conn = null;

Trường hợp này có một vấn đề như ở bài trước mình có trình bày đó là bạn phải truyền tên database vào chuỗi kết nối. Nhưng với trường hợp này thì ta không cần truyền tên database vào bởi vì ta đang sử dụng lệnh tạo database.

Bài viết này được đăng tại [free tuts .net]

2. Lời kết

Như vậy là mình đã giới thiệu xong ba cách tạo database bằng code PHP đơn giản nhất bằng hai thư viện PDO và MySQLi. Bài tiếp theo chúng ta sẽ tìm hiểu cách tạo database table bằng PHP.

Trong bài này, chúng ta sẽ tìm hiểu về cách tạo database và table trong MySQL với PHP. Để học tốt bài này, các bạn cần đọc lại bài Cài đặt môi trường lập trình Web PHP với XAMPP để biết cách chạy ứng dụng web PHP với XAMPP.

Hơn nữa, chúng ta cần kết nối MySQL với PHP trước khi tạo database và table. Cách kết nối MySQL và PHP được trình bày trong các bài Kết nối cơ sở dữ liệu MySQL với PHP sử dụng MySQLi và Kết nối cơ sở dữ liệu MySQL với PHP sử dụng PDO.

Sau khi đã tạo một kết nối đến MySQL trong XAMPP, các bạn có 2 cách để tạo các database trong MySQL:

Cách 1. Sử dụng công cụ phpMyAdmin để tạo database. Các bạn đọc lại phần Kết nối đến một database cụ thể trong MySQL để biết cách tạo database với phpMyAdmin.

Cách 2. Sử dụng PHP để thực thi câu lệnh “CREATE DATABASE” để tạo database trong MySQL.

Sử dụng MySQLi (object-oriented)

<?php
$servername = "localhost";
$username = "root";
$password = "";

// create connection
$conn = new mysqli($servername, $username, $password);

// check connection
if ($conn->connect_error) {
  die("Connection failed: " . $conn->connect_error);
}
// create database
$sql = "CREATE DATABASE IF NOT EXISTS gochocit";
if ($conn->query($sql) === TRUE) {
  echo "Database created successfully";
} else {
  echo "Error creating database: " . $conn->error;
}

$conn->close();
?>

Sử dụng MySQLi (procedural)

<?php
$servername = "localhost";
$username = "root";
$password = "";

// create connection
$conn = mysqli_connect($servername, $username, $password);

// check connection
if (!$conn) {
  die("Connection failed: " . $conn->connect_error);
}
// create database
$sql = "CREATE DATABASE IF NOT EXISTS gochocit";
if (mysqli_query($conn, $sql)) {
  echo "Database created successfully";
} else {
  echo "Error creating database: " . mysqli_error($conn);
}

mysqli_close($conn);
?>

Sử dụng PDO (PHP Data Object)

<?php
$servername = "localhost";
$username = "root";
$password = "";

try {
  $conn = new PDO("mysql:host=$servername", $username, $password);
  // set the PDO error mode to exception
  $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
  $sql = "CREATE DATABASE IF NOT EXISTS gochocit";
  // use exec() because no results are returned
  $conn->exec($sql);
  echo "Database created successfully<br>";
} catch(PDOException $e) {
  echo $sql . "<br>" . $e->getMessage();
}

$conn = null;
?>

2. Tạo table trong database trong MySQL

Để tạo table trong database, chúng ta sử dụng PHP để thực thi câu lệnh SQL là “CREATE TABLE”. Lưu ý, cần tạo kết nối đến database trong MySQL để tạo được table.

Sử dụng MySQLi (object-oriented)

<?php
$servername = "localhost";
$username = "root";
$password = "";
$dbname = "gochocit";

// create connection
$conn = new mysqli($servername, $username, $password, $dbname);

// check connection
if ($conn->connect_error) {
  die("Connection failed: " . $conn->connect_error);
}
// sql to create table
$sql = "CREATE TABLE IF NOT EXISTS gochocit_posts (
  ID INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
  post_author VARCHAR(255),
  post_title TEXT,
  post_content TEXT,
  post_date DATETIME)";
  
if ($conn->query($sql) === TRUE) {
  echo "Table gochocit_posts created successfully";
} else {
  echo "Error creating table: " . $conn->error;
}
  
  $conn->close();
?>

Sử dụng MySQLi (procedural)

<?php
$servername = "localhost";
$username = "root";
$password = "";
$dbname = "gochocit";

// create connection
$conn = mysqli_connect($servername, $username, $password, $dbname);

// check connection
if (!$conn) {
  die("Connection failed: " . $conn->connect_error);
}
// sql to create table
$sql = "CREATE TABLE IF NOT EXISTS gochocit_posts (
  ID INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
  post_author VARCHAR(255),
  post_title TEXT,
  post_content TEXT,
  post_date DATETIME)";
  
if (mysqli_query($conn, $sql)) {
  echo "Table gochocit_posts created successfully";
} else {
  echo "Error creating table: " . mysqli_error($conn);
}
  
  mysqli_close($conn);
?>

Sử dụng PDO (PHP Data Object)

<?php
$servername = "localhost";
$username = "root";
$password = "";
$dbname = "gochocit";

try {
  $conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);
  // set the PDO error mode to exception
  $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

  // sql to create table
  $sql = "CREATE TABLE IF NOT EXISTS gochocit_posts (
    ID INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
    post_author VARCHAR(255),
    post_title TEXT,
    post_content TEXT,
    post_date DATETIME)";  

  // use exec() because no results are returned
  $conn->exec($sql);
  echo "Table gochocit_posts created successfully";
} catch(PDOException $e) {
  echo "<br>" . $e->getMessage();
}

$conn = null;
?>

Hướng dẫn tạo database php

Trong các ví dụ trên, chúng ta tạo ra một table gochocit_posts trong database gochocit. Sử dụng lệnh IF NOT EXISTS để kiểm tra table đã tồn tại chưa, nếu chưa thì sẽ tạo table.

  • Các thao tác cơ bản trên danh sách liên kết đơn (Singly Linked List)
  • Sử dụng hàm print_r, var_dump, var_export trong PHP
  • Chương trình tính giai thừa (factorial) trong Java
  • Khái niệm lớp và đối tượng trong lập trình hướng đối tượng
  • Thuật toán là gì? Các phương pháp biểu diễn thuật toán