Previously I've asked about inserting a column into a dataset. I now have a similar question...namely merging two or more columns into a single column.
Lets say I have the following data set:
DataSet ds = new DataSet();
ds.Tables.Add(new DataTable());
ds.Tables[0].Columns.Add("id", typeof(int));
ds.Tables[0].Columns.Add("firstname", typeof(string));
ds.Tables[0].Columns.Add("lastname", typeof(string));
I am needing to combine the "firstname" and "lastname" columns into a single column called "name".
Would it be best for me to create a method that merges two columns together or a more general one that can be used to merge multiple columns together?
My idea is to create a generalized method sort of like the following:
MergeColumns(string format, string mergedColumn, DataTable dt, params string[] columnsToMerge)
The user supplies a format as follows: "{0} {1}"
mergedColumn is the name of the new column...but it must be able to be the same as one of the columns that will be merged cause in my real world case I'm merging "name" and "given_names" into "name"...but I still want to be able to use it if I ever needed to merge "street", "city", "state" "postcode" etc into a column called "address".
The way I am thinking this would be used is as follows:
MergeColumns("{0} {1}", "name", dataTable, "firstname", "lastname");
given the above dataset, I would expect the resultant data set to look as follows:
DataSet ds = new DataSet();
ds.Tables.Add(new DataTable());
ds.Tables[0].Columns.Add("id", typeof(int));
ds.Tables[0].Columns.Add("name", typeof(string));
Does this seem like a reasonable approach? Does a method like this already exist? I don't want to reinvent the wheel. Also, am I creating a method that does more than I actually need right now?