佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > DataTable多列合并問題輕松搞定

DataTable多列合并問題輕松搞定

熱門標簽:Linux服務器 電子圍欄 銀行業(yè)務 服務器配置 科大訊飛語音識別系統(tǒng) 阿里云 團購網(wǎng)站 Mysql連接數(shù)設置
問題背景
在做考試系統(tǒng)手動生成試卷部分時由于題庫的表結構不相同,導致同樣的Gridview(已模板化后的,其結構已固定)在顯示時不能同時兩種不同結構的數(shù)據(jù)。如GridView結構如下所示:
 
這種固定的格式顯示的是以選擇題為代表的數(shù)據(jù)結構,但是因為選擇題題庫表結構與論述題題庫表結構不相同,所以無法直接顯示以論述題為代表的數(shù)據(jù)結構。這時如何在這個固定的GridView中顯示不同的數(shù)據(jù)呢?其實在仔細觀察后我們可以發(fā)現(xiàn)他們唯一的區(qū)別在于“答案”這列的數(shù)據(jù)不同,在選擇題類型中,該字段的值僅為一個選項而已,但是對于論述題等類型,其問題有六個,對應的答案也應該有六列才對。分析到此,可以總結一下,最終要解決的問題是如何將六列的答案顯示在一列。

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

#region 根據(jù)動態(tài)生成的數(shù)據(jù)庫表名,從該表中選出QuestionId,ChapterId,QuestionTypeId,Point,不包括難度等級約束
/// summary>
/// 根據(jù)動態(tài)生成的數(shù)據(jù)庫表名,從該表中選出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("從動態(tài)生成的數(shù)據(jù)庫表中獲取QuestionId,ChapterId,QuestionTypeId,Point失?。ú话y度等級)");
}
finally
{
sqlHelper.Close();
}
}
#endregion

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

標簽:蚌埠 萍鄉(xiāng) 江蘇 衢州 衡水 廣元 大理 棗莊

巨人網(wǎng)絡通訊聲明:本文標題《DataTable多列合并問題輕松搞定》,本文關鍵詞  ;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    锡林郭勒盟| 黔东| 永新县| 黔西县| 上杭县| 黔南| 遵义市| 集安市| 四子王旗| 昭平县| 松滋市| 大宁县| 阿荣旗| 永济市| 宣汉县| 芮城县| 景洪市| 临夏县| 于田县| 孟津县| 凌海市| 拉孜县| 远安县| 永昌县| 五莲县| 积石山| 汉源县| 珠海市| 二手房| 泰和县| 桐乡市| 红桥区| 高台县| 青海省| 新乡市| 志丹县| 白水县| 治多县| 越西县| 修水县| 大同市|