ADO.NET - 动态循环遍历 SqlDataReader 列并将这些值分配给 C# Object

问题描述

我有一个应用程序,学生可以使用该应用程序选择他们希望加入的大学,在该应用程序中,我们目前提供最多选择 3 所大学的选项,我们说第一首选、第二首选和第三首选,我们有一个存储过程返回的数据和结果集的列如下。

 UserId | FirstName | LastName | Email | Mobile | City |
 FirstPreferredCollegeId | FirstPreferredCollegeName |
 FirstPreferredCollegeGrade | FirstPreferredCollegePincode |
 SecondPreferredCollegeId | SecondPreferredCollegeName |
 SecondPreferredCollegeGrade | SecondPreferredCollegePincode |
 ThirdPreferredCollegeId | ThirdPreferredCollegeName |
 ThirdPreferredCollegeGrade | ThirdPreferredCollegePincode |

如果我们查看上面的结果集 UserId、FirstName、LastName、Email、Mobile、City 是唯一的,其中 PreferredCollegeId、PreferredCollegeName、PreferredCollegeGrade、PreferredCollegePinCode 重复三次。

我的 c# 模型如下所示。

Public Class User
{
    Public int UserId {get;set;}
    Public string FirstName {get;set;}
    public string LastName {get;set;}
    public string Email {get;set;}
    public string Mobile {get;set;}
    public string City {get;set;}
    public List<Choice> Choices {get;set;}
}

public class Choice
{
    public string PreferredCollegeId {get;set;}
    public string PreferredCollegeName {get;set;}
    public string PreferredCollegeGrade {get;set;}
    public string PreferredCollegePincode {get;set;}
}

现在 ADO.NET 代码如下所示,reader 是 sqlDataReader 对象。

 objUser.UserId = (string)reader["UserId"];
 objUser.FirstName = (string)reader["FirstName"];
 objUser.LastName = (string)reader["LastName"];
 objUser.Email = (string)reader["Email"];
 objUser.Mobile = (string)reader["Mobile"];
 objUser.City = (string)reader["City"];

 /* Here I need to loop through reader and get College details
 Choice ch = new Choice();

现在我需要遍历 sqlDataReader获取 PreferredCollegeId、PreferredCollegeName、PreferredCollegeGrade、PreferredCollegePincode 并动态创建 Choice 类的对象并将这些值绑定到 Choice 对象 - 我该如何实现?

>

解决方法

尝试这样的事情:

var prefixes = new List<string> {"First","Second","Third"};
objUser.Choices = new List<Choice>();
foreach(var prefix in prefixes) 
{
   objUser.Choices.Add(new Choice {
       PreferredCollegeId= (string) reader[prefix + "PreferredCollegeId"],PreferredCollegeName = (string) reader[prefix + "PreferredCollegeName"],PreferredCollegeGrade  = (string) reader[prefix + "PreferredCollegeGrade"],PreferredCollegePincode  = (string) reader[prefix + "PreferredCollegePincode"]
   });
}

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...