中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

DataTable如何解決多列合并問題

發布時間:2021-10-12 14:46:31 來源:億速云 閱讀:143 作者:小新 欄目:開發技術

小編給大家分享一下DataTable如何解決多列合并問題,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

問題背景
在做考試系統手動生成試卷部分時由于題庫的表結構不相同,導致同樣的Gridview(已模板化后的,其結構已固定)在顯示時不能同時兩種不同結構的數據。如GridView結構如下所示:
DataTable如何解決多列合并問題 
這種固定的格式顯示的是以選擇題為代表的數據結構,但是因為選擇題題庫表結構與論述題題庫表結構不相同,所以無法直接顯示以論述題為代表的數據結構。這時如何在這個固定的GridView中顯示不同的數據呢?其實在仔細觀察后我們可以發現他們唯一的區別在于“答案”這列的數據不同,在選擇題類型中,該字段的值僅為一個選項而已,但是對于論述題等類型,其問題有六個,對應的答案也應該有六列才對。分析到此,可以總結一下,最終要解決的問題是如何將六列的答案顯示在一列。

解決辦法:將六個字段中的內容用sql語句實現合并,將其作為一個新的字段顯示出來,具體的實現請看代碼:

復制代碼 代碼如下:


#region 根據動態生成的數據庫表名,從該表中選出QuestionId,ChapterId,QuestionTypeId,Point,不包括難度等級約束
/// <summary>
/// 根據動態生成的數據庫表名,從該表中選出QuestionId,ChapterId,QuestionTypeId,Point,
/// Degree,Fraction,QuestioinContent,IsValid等內容,不包括難度等級約束
/// </summary>
/// <param name="strDataTableName"></param>
/// <returns></returns>
public DataTable BindQuestion(string strTableName,string strChapterName,string strQuestionTypeName)
{
try
{
DataTable dt = new DataTable ();
if (strQuestionTypeName != "論述題" && strQuestionTypeName != "案例分析題")
{
strsql = "select * from " + strTableName + " where ChapterId=@chapterid and QuestionTypeId=@questiontypeid";
}
else
{
strsql = "select QuestionId,ChapterId,QuestionTypeId,Point,Degree,Fraction,QuestionContent,cast(Answer1 as nvarchar(4000)) + cast(Answer2 as nvarchar(4000)) + cast(Answer3 as nvarchar(4000)) + cast(Answer4 as nvarchar(4000)) + cast(Answer5 as nvarchar(4000)) + cast(Answer6 as nvarchar(4000)) AS CorrectAnswer,IsValid from " + strTableName + " where ChapterId=@chapterid and QuestionTypeId=@questiontypeid";
}
//strsql = "select * from " + strTableName + " where ChapterId=@chapterid and QuestionTypeId=@questiontypeid";
SqlParameter[] paras = new SqlParameter[]{
new SqlParameter("@chapterid",strChapterName),
new SqlParameter("@questiontypeid",strQuestionTypeName)
};
dt = sqlHelper.ExecuteQuery(strsql,paras,CommandType.Text);
return dt;
}
catch
{
throw new Exception("從動態生成的數據庫表中獲取QuestionId,ChapterId,QuestionTypeId,Point失敗(不包括難度等級)");
}
finally
{
sqlHelper.Close();
}
}
#endregion


其中使用cast函數的strSql語句所起到的作用就是將多個字段合并成一個新字段。另外需要注意的是strSql語句中的 “ + ” 號,如果需要合并的字段的內容是Text類型的,是不支持該符號的,這時我們需要將其轉換成nvarchar類型。到此多列合并問題完美解決。

以上是“DataTable如何解決多列合并問題”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

新建县| 黄山市| 淮安市| 黄平县| 马龙县| 富平县| 城口县| 温州市| 土默特左旗| 高雄市| 区。| 五莲县| 凤翔县| 勃利县| 收藏| 崇仁县| 华池县| 泰来县| 罗源县| 边坝县| 隆德县| 河西区| 望奎县| 安徽省| 五莲县| 夏邑县| 靖安县| 潍坊市| 磴口县| 东宁县| 手游| 马公市| 富源县| 原阳县| 台州市| 凤城市| 台北市| 登封市| 津南区| 渝北区| 杂多县|