欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

DataTable多列合并問(wèn)題輕松搞定

 更新時(shí)間:2013年04月03日 15:42:19   作者:  
由于題庫(kù)的表結(jié)構(gòu)不相同,導(dǎo)致同樣的Gridview在顯示時(shí)不能同時(shí)兩種不同結(jié)構(gòu)的數(shù)據(jù),這時(shí)如何在這個(gè)固定的GridView中顯示不同的數(shù)據(jù)呢,感興趣的朋友可以看下本文的解決方法
問(wèn)題背景
在做考試系統(tǒng)手動(dòng)生成試卷部分時(shí)由于題庫(kù)的表結(jié)構(gòu)不相同,導(dǎo)致同樣的Gridview(已模板化后的,其結(jié)構(gòu)已固定)在顯示時(shí)不能同時(shí)兩種不同結(jié)構(gòu)的數(shù)據(jù)。如GridView結(jié)構(gòu)如下所示:
 
這種固定的格式顯示的是以選擇題為代表的數(shù)據(jù)結(jié)構(gòu),但是因?yàn)檫x擇題題庫(kù)表結(jié)構(gòu)與論述題題庫(kù)表結(jié)構(gòu)不相同,所以無(wú)法直接顯示以論述題為代表的數(shù)據(jù)結(jié)構(gòu)。這時(shí)如何在這個(gè)固定的GridView中顯示不同的數(shù)據(jù)呢?其實(shí)在仔細(xì)觀察后我們可以發(fā)現(xiàn)他們唯一的區(qū)別在于“答案”這列的數(shù)據(jù)不同,在選擇題類型中,該字段的值僅為一個(gè)選項(xiàng)而已,但是對(duì)于論述題等類型,其問(wèn)題有六個(gè),對(duì)應(yīng)的答案也應(yīng)該有六列才對(duì)。分析到此,可以總結(jié)一下,最終要解決的問(wèn)題是如何將六列的答案顯示在一列。

解決辦法:將六個(gè)字段中的內(nèi)容用sql語(yǔ)句實(shí)現(xiàn)合并,將其作為一個(gè)新的字段顯示出來(lái),具體的實(shí)現(xiàn)請(qǐng)看代碼:
復(fù)制代碼 代碼如下:

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

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

相關(guān)文章

  • VB.NET驗(yàn)證郵件地址的合法性實(shí)現(xiàn)代碼

    VB.NET驗(yàn)證郵件地址的合法性實(shí)現(xiàn)代碼

    現(xiàn)在,對(duì)于用戶在Web頁(yè)面上或電話中給出的Email地址,我們?cè)絹?lái)越不敢肯定它是否真的有效。在今天這個(gè)垃圾郵件泛濫成災(zāi)的年代,人們完全有理由舍不得輕易透露Email地址。
    2011-04-04
  • ASP.NET中的DataGridView綁定數(shù)據(jù)和選中行刪除功能具體實(shí)例

    ASP.NET中的DataGridView綁定數(shù)據(jù)和選中行刪除功能具體實(shí)例

    廢話就不多說(shuō)了,都說(shuō).NET是托控件的,我就托給你們看,這個(gè)博文主要講 DataGridView 的數(shù)據(jù)綁定,和選中行刪除功能
    2013-12-12
  • WeakReference(弱引用)讓GC需要時(shí)回收對(duì)象

    WeakReference(弱引用)讓GC需要時(shí)回收對(duì)象

    我們平常用的都是對(duì)象的強(qiáng)引用,如果有強(qiáng)引用存在,GC是不會(huì)回收對(duì)象的,我們能不能同時(shí)保持對(duì)對(duì)象的引用,而又可以讓GC需要的時(shí)候回收這個(gè)對(duì)象呢?本文將為您詳細(xì)解答,需要了解的朋友可以參考下
    2012-12-12
  • asp.net彈出窗口 返回值

    asp.net彈出窗口 返回值

    這篇文章主要介紹了asp.net彈出窗口 返回值,有需要的朋友可以參考一下
    2014-01-01
  • 如何在Asp.Net Core中集成Refit

    如何在Asp.Net Core中集成Refit

    這篇文章主要介紹了如何在Asp.Net Core中集成Refit,幫助大家更好的理解和學(xué)習(xí)使用Asp.Net Core,感興趣的朋友可以了解下
    2021-03-03
  • EF使用Code First模式給實(shí)體類添加復(fù)合主鍵

    EF使用Code First模式給實(shí)體類添加復(fù)合主鍵

    這篇文章介紹了EF使用Code First模式給實(shí)體類添加復(fù)合主鍵的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-03-03
  • C#中HTML字符轉(zhuǎn)換函數(shù)分享

    C#中HTML字符轉(zhuǎn)換函數(shù)分享

    在ASP.Net中經(jīng)常會(huì)從網(wǎng)面中取數(shù)據(jù)或更新網(wǎng)頁(yè)的顯示。因?yàn)镠TML中有些特殊字符如<, >, &等,顯示實(shí)際值不一致,造成保存到數(shù)據(jù)庫(kù)再取出來(lái)時(shí)會(huì)不一樣
    2012-07-07
  • ASP.NET 固定標(biāo)題列與欄位的具體實(shí)現(xiàn)

    ASP.NET 固定標(biāo)題列與欄位的具體實(shí)現(xiàn)

    客戶提這個(gè)要求很久了,最近才時(shí)間弄,但是看到百度中要沒有很多詳細(xì)的代碼。廢話不多說(shuō)直接貼代碼。
    2013-06-06
  • asp.net core 多文件分塊同時(shí)上傳的組件

    asp.net core 多文件分塊同時(shí)上傳的組件

    分享一個(gè)可多個(gè)文件同時(shí)上傳、斷點(diǎn)續(xù)傳,并實(shí)時(shí)反饋上傳進(jìn)度的 Asp.Net core 組件,本文通過(guò)實(shí)例代碼對(duì)asp.net core 多文件分塊同時(shí)上傳的組件知識(shí)介紹的非常詳細(xì),感興趣的朋友一起看看吧
    2023-12-12
  • ASP.NET MVC5網(wǎng)站開發(fā)管理列表、回復(fù)及刪除(十三)

    ASP.NET MVC5網(wǎng)站開發(fā)管理列表、回復(fù)及刪除(十三)

    這篇文章主要介紹了ASP.NET MVC5網(wǎng)站開發(fā)實(shí)現(xiàn)管理列表、回復(fù)及刪除,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2015-09-09

最新評(píng)論