- Chuyên mục khác :
- Git cơ bản và nâng cao
- ·
- MySQL cơ bản và nâng cao
- ·
- MongoDB cơ bản và nâng cao
- ·
- SQL cơ bản và nâng cao
- ·
- Linux cơ bản và nâng cao
- Học MySQL cơ bản và nâng cao
- Học MySQL cơ bản và nâng cao
- MySQL là gì
- Cài đặt MySQL
- Quản lý MySQL
- Cú pháp kết hợp MySQL và PHP
- Kết nối MySQL
- Tạo Database trong MySQL
- Xóa cơ sở dữ liệu trong MySQL
- Chọn cơ sở dữ liệu trong MySQL
- Kiểu dữ liệu trong MySQL
- Tạo bảng trong MySQL
- Xóa bảng trong MySQL
- Truy vấn INSERT trong MySQL
- Truy vấn SELECT trong MySQL
- Mệnh đề WHERE trong MySQL
- Truy vấn UPDATE trong MySQL
- Truy vấn DELETE trong MySQL
- Mệnh đề LIKE trong MySQL
- Mệnh đề ORDER BY trong MySQL
- Sử dụng JOIN trong MySQL
- Xử lý giá trị NULL trong MySQL
- Regexp trong MySQL
- Transaction trong MySQL
- Lệnh ALTER trong MySQL
- Chỉ mục (INDEX) trong MySQL
- Bảng tạm trong MySQL
- Mô phỏng bảng trong MySQL
- Lấy và sử dụng MySQL Metadata
- Sử dụng Sequence trong MySQL
- Xử lý bản sao trong MySQL
- Injection trong MySQL và SQL
- Export và Phương thức Backup trong MySQL
- Import và phương thức Recovery trong MySQL
- Mệnh đề GROUP BY trong MySQL
- Mệnh đề IN trong MySQL
- Mệnh đề BETWEEN trong MySQL
- Từ khóa UNION trong MySQL
- Hàm hữu ích trong MySQL
SELF JOIN trong SQL được sử dụng để kết hợp một bảng với chính nó như khi coi bảng đó là hai bảng, thay tên tạm thời ít nhất một bảng trong lệnh SQL.
Cú pháp
Cú pháp cơ bản của SELF JOIN trong SQL như sau:
SELECT a.ten_cot, b.ten_cot... FROM bang1 a, bang1 b WHERE a.field_chung = b.field_chung;
Ở đây, mệnh đề WHERE có thể là bất kỳ biểu thức nào theo yêu cầu của bạn.
Ví dụ
Giả sử có hai bảng, bảng NHANVIEN có các bản ghi sau:
+----+----------+-----+-----------+----------+ | ID | TEN | TUOI | DIACHI | LUONG | +----+----------+-----+-----------+----------+ | 1 | Hoang | 32 | DongDa | 2000.00 | | 2 | Thanh | 25 | QuangTrung | 1500.00 | | 3 | Viet | 23 | KimLien | 2000.00 | | 4 | Nhan | 25 | BaDinh | 6500.00 | | 5 | Huong | 27 | CauGiay | 8500.00 | | 6 | Long | 22 | TrungKinh | 4500.00 | | 7 | Nam | 24 | GiapBat | 10000.00 | +----+----------+-----+-----------+----------+
Bây giờ, chúng ta kết hợp bảng này với chính nó bởi sử dụng SELF JOIN trong SQL như sau:
SQL> SELECT a.ID, b.NAME, a.LUONG FROM NHANVIEN a, NHANVIEN b WHERE a.LUONG < b.LUONG;
Ví dụ trên sẽ cho kết quả:
+----+----------+---------+ | ID | TEN | LUONG | +----+----------+---------+ | 2 | Hoang | 1500.00 | | 2 | Viet | 1500.00 | | 1 | Nhan | 2000.00 | | 2 | Nhan | 1500.00 | | 3 | Nhan | 2000.00 | | 6 | Nhan | 4500.00 | | 1 | Huong | 2000.00 | | 2 | Huong | 1500.00 | | 3 | Huong | 2000.00 | | 4 | Huong | 6500.00 | | 6 | Huong | 4500.00 | | 1 | Long | 2000.00 | | 2 | Long | 1500.00 | | 3 | Long | 2000.00 | | 1 | Nam | 2000.00 | | 2 | Nam | 1500.00 | | 3 | Nam | 2000.00 | | 4 | Nam | 6500.00 | | 5 | Nam | 8500.00 | | 6 | Nam | 4500.00 | +----+----------+---------+
Bình luận (0)