- [DEVEXPRESS] Hỗ trợ tìm kiếm highlight không dấu và không khoảng cách trên Gridview Filter
- [C#] Chia sẻ source code phần mềm Image Downloader tải hàng loạt hình ảnh từ danh sách link url
- [C#] Chụp hình và quay video từ camera trên winform
- [C#] Chia sẽ full source code tách file Pdf thành nhiều file với các tùy chọn
- Giới thiệu về Stock Tracker Widget - Công cụ theo dõi cổ phiếu và cảnh báo giá tăng giảm bằng C# và WPF
- [VB.NET] Chia sẻ công cụ nhập số tiền tự động định dạng tiền tệ Việt Nam
- [VB.NET] Hướng dẫn fill dữ liệu từ winform vào Microsoft word
- [VB.NET] Hướng dẫn chọn nhiều dòng trên Datagridview
- Hướng Dẫn Đăng Nhập Nhiều Tài Khoản Zalo Trên Máy Tính Cực Kỳ Đơn Giản
- [C#] Chia sẻ source code phần mềm đếm số trang tập tin file PDF
- [C#] Cách Sử Dụng DeviceId trong C# Để Tạo Khóa Cho Ứng Dụng
- [SQLSERVER] Loại bỏ Restricted User trên database MSSQL
- [C#] Hướng dẫn tạo mã QRcode Style trên winform
- [C#] Hướng dẫn sử dụng temp mail service api trên winform
- [C#] Hướng dẫn tạo mã thanh toán VietQR Pay không sử dụng API trên winform
- [C#] Hướng Dẫn Tạo Windows Service Đơn Giản Bằng Topshelf
- [C#] Chia sẻ source code đọc dữ liệu từ Google Sheet trên winform
- [C#] Chia sẻ source code tạo mã QR MOMO đa năng Winform
- [C#] Chia sẻ source code phần mềm lên lịch tự động chạy ứng dụng Scheduler Task Winform
- [C#] Hướng dẫn download file từ Minio Server Winform
[SQLSERVER] Hướng dẫn join dũ liệu với comma separated
Xin chào các bạn bài viết hôm nay mình sẽ hướng dẫn các bạn join hai bảng sqlserver lại với nhau trên cột column được ngăn cách bởi dấu phẩy (,) hoặc bất kỳ ký tự gì tùy ý của bạn.
Để các bạn dễ hiểu mình sẽ demo hai bảng dữ liệu bên dưới.
1. Đây là bảng table với tên CourseMaster.

2. và bảng dữ liệu table 2 với tên StudentMaster
Các bạn thấy ở bảng thứ hai này, cột colunn Course có chứa các mã Course Id và được ngăn cách với nhau bới dấu phấy (,).
Vậy là thế nào để mình có thể join dữ liệu ví dụ: 01,02,06 => ABC,DEF,PQR
Và dưới đây là kết quả mong muốn của mình.
Bây giờ, các bạn hãy tạo 2 bảng table trên và chèn dữ liệu vào để demo nhé.
create table dbo.CourseMaster
(
  CourseId char(2),
  CourseName char(3)
);
create table dbo.StudentMaster
(
  ROLLNO char(5),
  NAME varchar(10),
  ADDRESS varchar(20),
  Course varchar(100)
);
insert into dbo.CourseMaster values
('01', 'ABC'),
('02', 'DEF'),
('03', 'GHI'),
('04', 'JKL'),
('05', 'MNO'),
('06', 'PQR'),
('07', 'STU');
insert into dbo.StudentMaster values
('12345', 'RAM',   'RAM ADDRESS',   '01,02,06'),                      
('25695', 'HARI',  'HARI ADDRESS',  '02,06'),                         
('89685', 'JEFF',  'JEFF ADDRESS',  '03,05,06,07'),                   
('47896', 'DAISY', 'DAISY ADDRESS', '03');Tiếp theo, các bạn chạy câu lệnh sau để join hai bảng cách nhau bởi ký tự sqlserver lại:
select SM.ROLLNO,
       SM.NAME, 
       SM.ADDRESS,
	   sm.Course,
       (
       select ','+CM.CourseName
       from dbo.CourseMaster as CM
       where ','+SM.Course+',' like '%,'+CM.CourseId+',%'
       for xml path(''), type
       ).value('substring(text()[1], 2)', 'varchar(max)') as Course2
from dbo.StudentMaster as SM;
Vậy là xong, hy vọng bài viết giúp ích được cho các bạn.
                                 
![[SQLSERVER] Hướng dẫn join dũ liệu với comma separated](https://laptrinhvb.net/uploads/users/9a8cb514e4428e85fb4ca07588e9103f.png)

![[SQL SERVER] Hướng dẫn tạo bảng cấu trúc cây theo phương pháp đệ quy](https://laptrinhvb.net/uploads/source/image_baiviet/69d43c06ca511fcc1812c830e8800506.png)
![[SQL SERVER] Hướng dẫn tránh trùng lắp dữ liệu trong lệnh Insert Into Select query](https://laptrinhvb.net/uploads/source/image_baiviet/6e5004146dd21886d7de227717fcdd24.jpg)
![[SQLSERVER] Hướng dẫn tạo xuất dữ liệu sang định dạng table html cho website](https://laptrinhvb.net/uploads/source/image_baiviet/87fa2b7873b2b5101a7ee85a3c2ceb22.jpg)
![[DATABASE] Thứ tự thực hiện mệnh đề truy vấn SELECT trong Sqlserver](https://laptrinhvb.net/uploads/source/DATABASE/sqlserver_wordwrap_thumb.png)
![[SQLSERVER] Sử dụng CTE (Common Table Expression) trong sql server](https://laptrinhvb.net/uploads/source/image_baiviet/18c66e81c87665252f73401932049735.jpg)
![[SQL SERVER] Hướng dẫn sử dụng hàm  STRING_SPLIT tách chuỗi thành bảng table](https://laptrinhvb.net/uploads/source/image_baiviet/436ae8fc96a85fa48fae6365928a33ef.jpg)
![[DATABASE] Sử dụng SESSION trong sqlserver](https://laptrinhvb.net/uploads/source/image_baiviet/aaf3db95351e2fa5afbc3d344fabc6cb.jpg)
![[SQLSERVER] Hướng dẫn tạo dữ liệu lớn (Big Data) mẫu test trong sql](https://laptrinhvb.net/uploads/source/image_baiviet/cb0ba24cddf688af8fab9b3702206276.jpg)
![[MYSQL] Cấu hình đồng bộ hai database mysql server MySQL Replication](https://laptrinhvb.net/uploads/source/DATABASE/mysql-procedure.png)
![[SQL] Hướng dẫn tạo mã code (mã phiếu)  tự động  trong SQL SERVER 2016](https://laptrinhvb.net/uploads/source/image_baiviet/be3d9b6527742e22868bfda626e5fbbf.png)
![[SQLSERVER] Kiểm tra file có tồn tại trong thư mục hệ thống](https://laptrinhvb.net/uploads/source/image_baiviet/a99b8ec3f15771e71e6c821a06b5de21.jpg)
![[DATABASE] Hướng dẫn sử dụng cURL Rest Api json trong sql server](https://laptrinhvb.net/uploads/source/DATABASE/rest_api_sqlserver_thumb.jpg)
![[DATABASE] Hướng dẫn kích hoạt giao diện Dark trong công cụ Sqlserver Management Studio](https://laptrinhvb.net/uploads/source/image_baiviet/d0b932807f67ad451f515c36a7b48534.jpg)
![[DATABASE] Xóa lịch sử danh sách đăng nhập tài khoản trên SMSS Sqlserver Management Studio](https://laptrinhvb.net/uploads/source/DATABASE/delete_login_smss.png)
![[SQLSERVER] Sử dụng câu lệnh MERGE Statement](https://laptrinhvb.net/uploads/source/image_baiviet/beba152188e9a46c5f537d79980d04e7.jpg)
![[SQLSERVER] Tách viết tắt tên FirstName và LastName](https://laptrinhvb.net/uploads/source/image_baiviet/1fed79f6e3950d1c80655e0bbe718114.jpg)
![[SQLSERVER] Backup and Restore Database từ phiên bản cao xuống phiên bản thấp (Migrate database sql)](https://laptrinhvb.net/uploads/source/DATABASE/data_mirgate_thumb.png)
![[SQLSERVER] Xem lịch sử đăng nhập hệ thống và các câu truy vấn đã thực hiện trong database](https://laptrinhvb.net/uploads/source/image_baiviet/0f32047d9ae0c1d18d5d78c6d9889ac2.jpg)
![[DATABASE] Chia sẻ dữ liệu Pantone Color sql và json api](https://laptrinhvb.net/uploads/source/DATABASE/panton_color.png)
![[DATABASE] Hướng dẫn hiển thị phần trăm process thực hiện công việc Backup và Restore Database Sqlserver](https://laptrinhvb.net/uploads/source/image_baiviet/716ebfb40a00085aba33c1eb4054d732.png)
![[SQLSERVER] Hướng dẫn giảm bớt dung lượng file Log Database](https://laptrinhvb.net/uploads/source/image_baiviet/210dacb6311c4c81350ac7d9f23d75cd.png)
![[SQLSERVER] Hướng dẫn di chuyển dữ liệu giữa các table (Insert into ... Select ... from)](https://laptrinhvb.net/uploads/source/image_baiviet/7c63ddd376850ef2b3e84625393e0f4d.png)
