DataTable多列合并问题轻松搞定

 更新时间:2013年04月03日 15:42:19   作者:  
由于题库的表结构不相同,导致同样的Gridview在显示时不能同时两种不同结构的数据,这时如何在这个固定的GridView中显示不同的数据呢,感兴趣的朋友可以看下本文的解决方法
问题背景
在做考试系统手动生成试卷部分时由于题库的表结构不相同,导致同样的Gridview(已模板化后的,其结构已固定)在显示时不能同时两种不同结构的数据。如GridView结构如下所示:
 
这种固定的格式显示的是以选择题为代表的数据结构,但是因为选择题题库表结构与论述题题库表结构不相同,所以无法直接显示以论述题为代表的数据结构。这时如何在这个固定的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类型。到此多列合并问题完美解决。

相关文章

  • VB.NET验证邮件地址的合法性实现代码

    VB.NET验证邮件地址的合法性实现代码

    现在,对于用户在Web页面上或电话中给出的Email地址,我们越来越不敢肯定它是否真的有效。在今天这个垃圾邮件泛滥成灾的年代,人们完全有理由舍不得轻易透露Email地址。
    2011-04-04
  • ASP.NET中的DataGridView绑定数据和选中行删除功能具体实例

    ASP.NET中的DataGridView绑定数据和选中行删除功能具体实例

    废话就不多说了,都说.NET是托控件的,我就托给你们看,这个博文主要讲 DataGridView 的数据绑定,和选中行删除功能
    2013-12-12
  • WeakReference(弱引用)让GC需要时回收对象

    WeakReference(弱引用)让GC需要时回收对象

    我们平常用的都是对象的强引用,如果有强引用存在,GC是不会回收对象的,我们能不能同时保持对对象的引用,而又可以让GC需要的时候回收这个对象呢?本文将为您详细解答,需要了解的朋友可以参考下
    2012-12-12
  • asp.net弹出窗口 返回值

    asp.net弹出窗口 返回值

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

    如何在Asp.Net Core中集成Refit

    这篇文章主要介绍了如何在Asp.Net Core中集成Refit,帮助大家更好的理解和学习使用Asp.Net Core,感兴趣的朋友可以了解下
    2021-03-03
  • EF使用Code First模式给实体类添加复合主键

    EF使用Code First模式给实体类添加复合主键

    这篇文章介绍了EF使用Code First模式给实体类添加复合主键的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • C#中HTML字符转换函数分享

    C#中HTML字符转换函数分享

    在ASP.Net中经常会从网面中取数据或更新网页的显示。因为HTML中有些特殊字符如<, >, &等,显示实际值不一致,造成保存到数据库再取出来时会不一样
    2012-07-07
  • ASP.NET 固定标题列与栏位的具体实现

    ASP.NET 固定标题列与栏位的具体实现

    客户提这个要求很久了,最近才时间弄,但是看到百度中要没有很多详细的代码。废话不多说直接贴代码。
    2013-06-06
  • asp.net core 多文件分块同时上传的组件

    asp.net core 多文件分块同时上传的组件

    分享一个可多个文件同时上传、断点续传,并实时反馈上传进度的 Asp.Net core 组件,本文通过实例代码对asp.net core 多文件分块同时上传的组件知识介绍的非常详细,感兴趣的朋友一起看看吧
    2023-12-12
  • ASP.NET MVC5网站开发管理列表、回复及删除(十三)

    ASP.NET MVC5网站开发管理列表、回复及删除(十三)

    这篇文章主要介绍了ASP.NET MVC5网站开发实现管理列表、回复及删除,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2015-09-09

最新评论