By using DataTable DefaultView.ToTable() method we can get the distinct values of required columns of a datatable. the following example will explain how to do that.
DataTable dt = new DataTable("ResultSet");
dt.Columns.Add("Country");
dt.Columns.Add("State");
dt.Columns.Add("Place");
dt.Rows.Add("India", "Andhrapradesh", "Charminar");
dt.Rows.Add("India", "Andhrapradesh", "Steel Plant");
dt.Rows.Add("India", "Maharastra", "IT Hub");
dt.Rows.Add("India", "Tamilnadu", "Beach House");
dt.Rows.Add("India", "Tamilnadu", "Club House");
dt.Rows.Add("USA", "Dallas", "Airport");
dt.Rows.Add("Australia", "Sydney", "Stadium");
DataTable dtCountry = dt.DefaultView.ToTable("Countries", true, "Country");
DataTable dttemp = dt.DefaultView.ToTable("Temp", true, "Country", "State");
In the above example dtCountry will contain the distinct Countries and dttemp will contain the distinct Countries and States.
Output of "dt"
data:image/s3,"s3://crabby-images/b750b/b750b6d08849b0b1fe097526ec92997ee2032fd4" alt="image"
Output of DataTable dtCountry = dt.DefaultView.ToTable("Countries", true, "Country");
data:image/s3,"s3://crabby-images/10aeb/10aeb4d9e642dc8b0475296b4c2e5a5a47871c14" alt="image"
Output of DataTable dttemp = dt.DefaultView.ToTable("Temp", true, "Country", "State");
data:image/s3,"s3://crabby-images/0cd27/0cd27c365fd1fccdff4a3d2aa58753916fbe6944" alt="image"