国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 數(shù)據(jù)庫(kù) > SQL Server > 正文

sqlserver合并DataTable并排除重復(fù)數(shù)據(jù)的通用方法分享

2020-07-25 13:18:19
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
代碼如下:
復(fù)制代碼 代碼如下:

///<summary>
/// 將兩個(gè)列不同的DataTable合并成一個(gè)新的DataTable
///</summary>
///<param name="dt1">源表</param>
///<param name="dt2">需要合并的表</param>
///<param name="primaryKey">需要排重列表(為空不排重)</param>
///<param name="maxRows">合并后Table的最大行數(shù)</param>
///<returns>合并后的datatable</returns>
public static DataTable MergeDataTable(DataTable dt1, DataTable dt2, string primaryKey, int maxRows)
{
//判斷是否需要合并
if (dt1 == null && dt2 == null)
{
return null;
}
if (dt1 == null && dt2 != null)
{
return dt2.Copy();
}
else if (dt1 != null && dt2 == null)
{
return dt1.Copy();
}
//復(fù)制dt1的數(shù)據(jù)
DataTable dt = dt1.Copy();
//補(bǔ)充dt2的結(jié)構(gòu)(dt1中沒(méi)有的列)到dt中
for (int i = 0; i < dt2.Columns.Count; i++)
{
string cName = dt2.Columns[i].ColumnName;
if (!dt.Columns.Contains(cName))
{
dt.Columns.Add(new DataColumn(cName));
}
}
//復(fù)制dt2的數(shù)據(jù)
if (dt2.Rows.Count > 0)
{
Type t = dt2.Rows[0][primaryKey].GetType();
bool isNeedFilter = string.IsNullOrEmpty(primaryKey) ? false : true;
bool isNeedQuotes = t.Name == "String" ? true : false;
int mergeTableNum = dt.Rows.Count;
for (int i = 0; i < dt2.Rows.Count && mergeTableNum < maxRows; i++)
{
bool isNeedAdd = true;
//如果需要排重時(shí),判斷是否需要添加當(dāng)前行
if (isNeedFilter)
{
string primaryValue = dt2.Rows[i][primaryKey].ToString();
string fileter = primaryKey + "=" + primaryValue;
if(isNeedQuotes)
{
fileter = primaryKey + "='" + primaryValue + "'";
}
DataRow[] drs = dt.Select(fileter);
if (drs != null && drs.Length > 0)
{
isNeedAdd = false;
}
}
//添加數(shù)據(jù)
if (isNeedAdd)
{
DataRow dr = dt.NewRow();
for (int j = 0; j < dt.Columns.Count; j++)
{
string cName = dt.Columns[j].ColumnName;
if (dt2.Columns.Contains(cName))
{
//防止因同一字段不同類型賦值出錯(cuò)
if (dt2.Rows[i][cName] != null && dt2.Rows[i][cName] != DBNull.Value && dt2.Rows[i][cName].ToString() != "")
{
dr[cName] = dt2.Rows[i][cName];
}
}
}
dt.Rows.Add(dr);
mergeTableNum++;
}
}
}
return dt;
}
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 西和县| 万盛区| 德保县| 东乡| 景德镇市| 禄劝| 乌兰浩特市| 仙游县| 萨嘎县| 奈曼旗| 东城区| 顺义区| 龙州县| 正安县| 都昌县| 武清区| 墨竹工卡县| 陇川县| 辽源市| 遵义县| 辉南县| 海林市| 平果县| 元朗区| 阳新县| 中江县| 当雄县| 来凤县| 昌宁县| 稻城县| 自贡市| 乐至县| 仁寿县| 鹤峰县| 广西| 安溪县| 渝北区| 临高县| 庄浪县| 白沙| 增城市|