Hướng dẫn dùng free dbms trong 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ó.

Nội dung chính

  • 1. Tạo database bằng code PHP
  • Sử dụng MySQLi Object-oriented:
  • Sử dụng MySQLi Procedural:
  • Sử dụng PDO:
  • 2. Lời kết
  • Video Thao tác với cơ sở dữ liệu MySQL bằng MySQLi
  • Hướng dẫn chi tiết
  • Kết nối database
  • Khởi tạo database và tạo bảng
  • Thêm dữ liệu
  • Truy vấn dữ liệu
  • Sửa dữ liệu
  • Xóa dữ liệu
  • Đóng kết nối

Hướng dẫn dùng free dbms trong 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.

Việc thao tác với database trong quá trình phát triển và bảo trì website là công việc thường xuyên đối với những lập trình viên. Với mỗi database được tích hợp trong website thì chúng ta có nhiều cách thao tác khác nhau. Database thường được sử dụng nhiều khi kết hợp với PHP có thể kể đến MySQL. Trong bài học này, mình sẽ hướng dẫn các bạn thao tác với cơ sở dữ liệu MySQL bằng MySQLi.

  • Video Thao tác với cơ sở dữ liệu MySQL bằng MySQLi
  • Hướng dẫn chi tiết
    • Kết nối database
    • Khởi tạo database và tạo bảng
    • Thêm dữ liệu
    • Truy vấn dữ liệu
    • Sửa dữ liệu
    • Xóa dữ liệu
    • Đóng kết nối

Video Thao tác với cơ sở dữ liệu MySQL bằng MySQLi

Hướng dẫn chi tiết

"Ra đời, cuộc sống bươm chải, có làm vẫn không có ăn" nên phải gắn QUẢNG CÁO

Các bạn cần hosting WordPress nhanh, rẻ và dễ sử dụng có free SLL hãy chọn Azdigi nhé.
Link đăng ký: NHẬN NGAY ƯU ĐÃI
Nếu các bạn mua hosting từ link trên, mình sẽ có một ít tiền để duy trì. Cảm ơn

Kết nối database

Chúng ta sẽ kết nối với database bằng hàm mysqli_connect. Hàm này cần 4 tham số

  • hostname: nơi đặt database
  • username: tên người dùng database
  • password: mật khẩu người dùng database
  • dbname: tên database
$connect = mysqli_connect("hostname", "username", "password", "dbname");

Khởi tạo database và tạo bảng

Các câu truy vấn hoàn toàn giống như khi chúng ta thao tác trên phpMyadmin

$sql = "CREATE TABLE `mysqli`.`user` ( `id` INT UNSIGNED NOT NULL AUTO_INCREMENT , 
`username` VARCHAR(5) NULL DEFAULT NULL , 
`password` VARCHAR(5) NULL DEFAULT NULL , 
`email` VARCHAR(5) NULL DEFAULT NULL , 
PRIMARY KEY (`id`)) ENGINE = InnoDB;";
mysqli_query($connect, $sql);

Thêm dữ liệu

Chúng ta sẽ thử thêm 1 vài dòng dữ liệu vào bảng user nhé.

"Ra đời, cuộc sống bươm chải, có làm vẫn không có ăn" nên phải gắn QUẢNG CÁO

Các bạn cần hosting WordPress nhanh, rẻ và dễ sử dụng có free SLL hãy chọn Azdigi nhé.
Link đăng ký: NHẬN NGAY ƯU ĐÃI
Nếu các bạn mua hosting từ link trên, mình sẽ có một ít tiền để duy trì. Cảm ơn
$sql  = "INSERT INTO `user`(`username`, `password`, `email`) VALUES ('def',123,123)";
mysqli_query($connect, $sql);

Truy vấn dữ liệu

Chúng ta sẽ thử lấy tất cả dữ liệu trong bảng nhé.

$sql = "SELECT * FROM `user`";
$query = mysqli_query($connect, $sql);

Các bạn thử var_dump biến $query, xem thử kết quả trả về như thế nào nhé.

Kết quả là trả về là 1 object chứ không phải những dòng dữ liệu chúng ta mong muốn. Để tách dữ liệu, chúng ta cần xử lý như sau:

$arr_kq = array();
if(mysqli_num_rows($query) > 0){
    while($row = mysqli_fetch_assoc($query)){
        // var_dump($row);
        // duyệt qua từng dòng và thêm vào mảng kết quả
        array_push($arr_kq, $row);
    }
}
else{
    echo 'Khong co du lieu';
}
mysqli_close($connect);

Trên w3school có hướng dẫn rất chi tiết về phần Select này. Ngoài cách trên, chúng ta còn một cách Select theo kiểu hướng đối tượng. Bạn xem thêm tại đây nhé: https://www.w3schools.com/php/php_mysql_select.asp

Sửa dữ liệu

$sql = "UPDATE `user` SET `username` = 'thui', `password` = '234' WHERE `user`.`id` = 2;";
mysqli_query($connect, $sql);

Xóa dữ liệu

$sql = "DELETE FROM `user` WHERE `user`.`id` = 2";
mysqli_query($connect, $sql);

Đóng kết nối

mysqli_close($connect);

Tài liệu bài học: Download

Nếu có thắc mắc, hãy đặt câu hỏi bằng cách comment bên dưới, qua email, hoặc nhắn tin qua Fanpage Góc làm web.

Liên hệ