Trong bài này chúng ta sẽ học :
• Cách khởi động và sử dụng MYSQL.
• Loại dữ liệu trong Mysql
• Những cú pháp cơ bản hay sử dụng
MySQL là hệ quản trị cơ sở dữ liệu mã nguồn mở phổ biến nhất thế giới và được các nhà phát triển rất ưa chuộng trong quá trình phát triển ứng dụng.
Vì MySQL là cơ sở dữ liệu tốc độ cao, ổn định và dễ sử dụng, có tính khả chuyển, hoạt động trên nhiều hệ điều hành cung cấp một hệ thống lớn các hàm tiện ích rất mạnh.Với tốc độ và tính bảo mật cao, MySQL rất thích hợp cho các ứng dụng có truy cập CSDL trên internet.
MySQL miễn phí hoàn toàn cho nên bạn có thể tải về MySQL từ trang chủ. Nó có nhiều phiên bản cho các hệ điều hành khác nhau: phiên bản Win32 cho các hệ điều hành dòng Windows, Linux, Mac OS X, Unix, FreeBSD, NetBSD, Novell NetWare, SGI Irix, Solaris, SunOS, ... MySQL là một trong những ví dụ rất cơ bản về Hệ Quản trị Cơ sở dữ liệu quan hệ sử dụng Ngôn ngữ truy vấn có cấu trúc (SQL). MySQL được sử dụng cho việc bổ trợ PHP, Perl, và nhiều ngôn ngữ khác, nó làm nơi lưu trữ những thông tin trên các trang web viết bằng PHP hay Perl,...
1- Cách khởi động và sử dụng MYSQL.
Chúng ta sử dụng command như sau:
mysql –h host –u username –p;
• -h : sau do nhập tên host
• -u : sau đó nhập username
sau do nhap password.
Ví dụ : với localhost, username = root , pass= rỗng
mysql –h localhost –u root –p;
Để truy cập vào cơ sở dữ liệu.
2- Những định nghĩa cơ bản:
a) Định nghĩa cơ sở dữ liệu, bảng, cột:
• Cơ sở dữ liệu: là tên của cơ sở dữ liệu chúng ta muốn sử dụng
• Bảng: Là 1 bảng giá trị nằm trong cơ sở dữ liệu.
• Cột là 1 giá trị nằm trong bảng. Dùng để lưu trữ các trường dữ liệu.
Như vậy ta có thể hiểu như sau:
1 cơ sở dữ liệu có thể bao gồm nhiều bảng.
1 bảng có thể bao gồm nhiều cột
1 cột có thể có hoặc không có những thuộc tính.
b) Định nghĩa 1 số thuật ngữ:
NULL : Giá trị cho phép rỗng.
AUTO_INCREMENT : Cho phép giá trị tăng dần (tự động).
UNSIGNED : Phải là số nguyên dương
PRIMARY KEY : Cho phép nó là khóa chính trong bảng.
c)Loại dữ liệu trong Mysql:
Ở đây chúng tả chỉ giới thiệu 1 số loại thông dụng: 1 số dữ liệu khác có thể tham khảo trên trang chủ của mysql.
1 - Loại dữ liệu numeric gồm kiểu số nguyên và kiểu chấm động :
a. kiểu dữ liệu số nguyên
Loại Range Bytes Giải thích
Tinyint -127 đến 128 hay 0 …255 1 Số nguyên rất nhỏ.
Smallint -32768 đến 32767 hay 0…65535 2 Số nguyên nhỏ.
Mediumint -8388608 đến 838860 hay 0…16777215 3 Số nguyên vừa.
Int -231 đến 231 -1 hay 0…232 – 1 4 Số nguyên.
Bigint -263 đến 263 -1 hay 0…264 -1
8 Số nguyên lớn
b. bảng dữ liệu kiểu chấm động
Loại Range Bytes Diễn giải
float Phụ thuộc vào số thập phân Số thập phân dạng single hay double
Float(M,D) +/-1 . 175494351E-38
+/-3 . 40282346638 4 Số thập phân dạng single.
Double(M,D) +/-1 . 7976931348623157308
+/-2 . 2250738585072014E-308 8 Số thập phân dạng double
Float(M[,D]) Số chấm động lưu dưới dạng char.
2. Loại dữ liệu date and time: kiễu dữ liệu date and time cho phép bạn nhập liệu dưới dạng chuỗi ngày/ tháng/ năm hay dạng số.
Loại Range Diễn giải
Date 1000-01-01 đến 9999-12-31 Date trình bày dưới dạng yyyy-mm-dd.
Time 00:00:00 đến 23:59:59 Time trình bày dưới dạng hh:mm:ss.
Datetime 1000-01-01, 00:00:00 đến
9999-12-31, 23:59:59 Date và time trình bày dưới dạng yyyy-mm-dd, hh:mm:ss.
Timestamp[(M)] 1970-01-01, 00:00:00 Timestamp trình bày dưới dạng yyyy-mm-dd, hh:mm:ss.
Year [(2|4)] 1970 - 2069
1901 - 2155 Year trình bày dưới dạng 2 số hay 4 số.
3. Loại dữ liệu string:
- Kiểu dữ liệu string gồm có :
• loại thứ nhất như char(chiều dài cố định) và varchar(chiều dài biến thiên) :
• Loại thứ hai là text hay Blob, text cho phép lưu trữ rất lớn,blob cho phép lưu đối tượng nhị phân
• Loại thứ 3 là Enum và set
Loại Range Diễn giải
Char 1-255 characters Chiều dài của chuỗi lớn nhất 255 kí tự
Varchar 1-255 characters Chiều dài của chuỗi lớn nhất 255 kí tự (characters)
Tinyblob 28 -1 Khai báo cho Field chứa kiểu đối tượng nhị phân cỡ 255 characters
Tinytext 28 -1 Khai báo cho Field chứa kiểu chuỗi cỡ 255 character
Blob 216 -1 Khai báo cho Field chứa kiểu bolb cỡ 65,535 characters
Text 216 -1 Khai báo cho Field chứa kiểu chuỗi dạng văn bản cỡ 65,535 characters
Mediumbold 224-1 Khai báo cho Field chứa kiểu bolb vừa cỡ 16,777,215 characters
Mediumtext 224-1 Khai báo cho Field chứa kiểu chuỗi dạng văn bản vừa cỡ 16,777,215 characters
Longbold 232-1 Khai báo cho Field chứa kiểu bolb lớn khoảng 4,294,967,295 characters
Longtext 232-1 Khai báo cho Field chứa kiểu chuỗi dạng văn bản lớn khoảng 4,294,967,295 characters
3- Những cú pháp cơ bản:
• Cú pháp tạo 1 cơ sở dữ liệu: CREATE DATABASE tên_cơ_sở_dữ_liệu;
• Cú pháp sử dụng cơ sở dữ liệu: Use tên_database;
• Cú pháp thoát khỏi cơ sở dữ liệu: Exit
• Cú pháp tạo 1 bảng trong cơ sở dữ liệu:
CREATE TABLE tênbang (các cột ,…,…..)
Ví dụ:
mysql> CREATE TABLE employees (
Employees_ID int(11) NOT NULL AUTO_INCREMENT,
name varchar(255) DEFAULT NULL,
age int(11) DEFAULT NULL,
birthday datetime DEFAULT NULL,
PRIMARY KEY (Employees_ID)
) ENGINE=MyISAM AUTO_INCREMENT=4 DEFAULT CHARSET=latin1;
• Hiển thị có bao nhiều bảng: show tables;
• Hiển thị có bao nhiêu cột trong bảng: Describe table;
• Thêm 1 cột vào bảng :
ALTER TABLE tên_bảng ADD AFTER
Ví dụ:
ALTER TABLE `tblnews`
ADD COLUMN `ImageLink` varchar(255) NULL AFTER `Content`;
4- Thêm giá trị vào bảng:
Cú pháp:
INSERT INTO Tên_bảng(tên_cột) VALUES(Giá_trị_tương_ứng);
Ví dụ:
INSERT INTO employees VALUES (1, 'Dao thi Hai', '12', '2010-04-21 07:12:51');
INSERT INTO employees VALUES (2, 'Nguyen van Minh', '34', '2010-04-14 07:12:59');
INSERT INTO employees VALUES (3, 'BiNh', '45', '2010-04-01 07:13:02');
5- Truy xuất dữ liệu:
Cú pháp:
SELECT tên_cột FROM Tên_bảng;
Ví dụ:
6- Truy xuất dữ liệu với điều kiện:
Cú pháp:
SELECT tên_cột FROM Tên_bảng WHERE điều kiện;
Ví dụ:
7- Truy cập dữ liệu và sắp xếp theo trình tự
Cú pháp:
SELECT tên_cột FROM Tên_bảng
WHERE điều kiện (có thể có where hoặc không)
ORDER BY Theo quy ước sắp xếp.
Trong đó quy ước sắp xếp bao gồm hai thông số là ASC (từ trên xuống dưới), DESC (từ dưới lên trên).
Ví dụ :
8- Truy cập dữ liệu có giới hạn :
Cú pháp:
SELECT tên_cột FROM Tên_bảng
WHERE điều kiện (có thể có where hoặc không)
LIMIT vị trí bắt đầu, số record muốn lấy ra
Ví dụ:
9- Cập nhật dữ liệu trong bảng:
Cú pháp:
Update tên_bảng set tên_cột=Giá trị mới
WHERE (điều kiện).
Nếu không có ràng buộc điều kiện, chúng sẽ cập nhật toàn bộ giá trị mới của các record trong bảng.
Ví dụ:
10- Xóa dữ liệu trong bảng:
Cú pháp:
DELETE FROM tên_bảng WHERE (điều kiện).
Nếu không có điều kiện, sẽ xóa toàn bộ các record trong bảng.
Ví dụ
DELETE FROM `tblnews` WHERE (`ID`='17')