Nếu bạn đã biết rằng chỉ một số giá trị là cần thiết thì giải pháp tốt nhất là sử dụng kiểu dữ liệu ENUM. ENUM hạn chế hơn.
Nếu bạn không biết về các vaulues, thì bạn cần sử dụng kiểu dữ liệu TINYINT UNSIGNED. TINYINT UNSIGNED ít hạn chế hơn.
Hãy để chúng tôi triển khai kiểu dữ liệu ENUM, nếu bạn chỉ muốn lưu trữ 10,20,30. Sau đây là truy vấn -
mysql> create table DemoTable ( Id int NOT NULL AUTO_INCREMENT PRIMARY KEY, Number ENUM('10','20','30') ); Query OK, 0 rows affected (0.24 sec)
Chèn một số bản ghi vào bảng bằng lệnh chèn -
mysql> insert into DemoTable(Number) values('10'); Query OK, 1 row affected (0.07 sec) mysql> insert into DemoTable(Number) values('20'); Query OK, 1 row affected (0.06 sec) mysql> insert into DemoTable(Number) values('30'); Query OK, 1 row affected (0.06 sec) mysql> insert into DemoTable(Number) values('50'); ERROR 1265 (01000): Data truncated for column 'Number' at row 1
Hiển thị tất cả các bản ghi từ bảng bằng câu lệnh select -
mysql> select *from DemoTable;
Điều này sẽ tạo ra kết quả sau -
+----+--------+ | Id | Number | +----+--------+ | 1 | 10 | | 2 | 20 | | 3 | 30 | +----+--------+ 3 rows in set (0.00 sec)
Đây là việc triển khai TINYINT UNSIGNED. Hãy để chúng tôi tạo một bảng mới -
mysql> create table DemoTable ( Id int NOT NULL AUTO_INCREMENT PRIMARY KEY, Number tinyint unsigned ); Query OK, 0 rows affected (0.23 sec)
Chèn một số bản ghi vào bảng bằng lệnh chèn -
mysql> insert into DemoTable(Number) values(100); Query OK, 1 row affected (0.07 sec) mysql> insert into DemoTable(Number) values(50); Query OK, 1 row affected (0.17 sec) mysql> insert into DemoTable(Number) values(60); Query OK, 1 row affected (0.06 sec) mysql> insert into DemoTable(Number) values(70); Query OK, 1 row affected (0.07 sec)
Hiển thị tất cả các bản ghi từ bảng bằng câu lệnh select -
mysql> select *from DemoTable;
Điều này sẽ tạo ra kết quả sau -
+----+--------+ | Id | Number | +----+--------+ | 1 | 100 | | 2 | 50 | | 3 | 60 | | 4 | 70 | +----+--------+ 4 rows in set (0.00 sec)