Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/277.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/asp.net/29.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/video/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 如何在ASP.NET WebForms的实体框架中选择特定列?_C#_Asp.net_Webforms_Entity Framework 6 - Fatal编程技术网

C# 如何在ASP.NET WebForms的实体框架中选择特定列?

C# 如何在ASP.NET WebForms的实体框架中选择特定列?,c#,asp.net,webforms,entity-framework-6,C#,Asp.net,Webforms,Entity Framework 6,我只想从ASP.NET实体框架中的SQL Server数据库中选择特定列,如用户名、消息和主题。但是我的程序返回了emailtable表中的所有列 这是我的密码: kicsEntities db = new kicsEntities(); protected void Page_Load(object sender, EventArgs e) { emailtable et = new emailtable(); string var = Session["username"

我只想从ASP.NET实体框架中的SQL Server数据库中选择特定列,如用户名、消息和主题。但是我的程序返回了emailtable表中的所有列

这是我的密码:

kicsEntities db = new kicsEntities();

protected void Page_Load(object sender, EventArgs e)
{
    emailtable et = new emailtable();

    string var = Session["username"].ToString();

    GridView1.DataSource = db.emailtables.Where(em => em.receiver == var).ToList(); 
    GridView1.DataBind();
}

您可以将视图添加到数据库模型中,并使其仅包含希望检索的列。如果您的方法是“代码优先”,则可以按中所述添加/映射视图。

您可以将视图添加到数据库模型中,并使其仅包含您希望检索的列。如果您的方法是“代码优先”,则可以按中所述添加/映射视图。

您可以使用投影。例如,创建一个名为MyClass的视图模型c类,并从数据库对象声明所需的属性

public class MyClass
{
    public string Username { get; set; }
    public string Message { get; set; }
    public string Subject { get; set; }
}
现在使用Linq,您只能从数据库表中请求所需的属性

db.TableName.Select(m => new MyClass 
{
    Username = m.Username,
    Message = m.Message,
    Subject = m.Subject
});

现在,您可以将返回的集合绑定为gridview的数据源,并具有强类型控件的额外好处。

您可以使用投影。例如,创建一个名为MyClass的视图模型c类,并从数据库对象声明所需的属性

public class MyClass
{
    public string Username { get; set; }
    public string Message { get; set; }
    public string Subject { get; set; }
}
现在使用Linq,您只能从数据库表中请求所需的属性

db.TableName.Select(m => new MyClass 
{
    Username = m.Username,
    Message = m.Message,
    Subject = m.Subject
});

现在,您可以将返回的集合绑定为gridview的数据源,并具有强类型控件的额外好处。

您需要创建一个具有所需属性的ViewModel类,然后使用继续查询。Selectx=>new Vm{…}。ToList您需要创建一个具有所需属性的ViewModel类,然后使用.Selectx=>newVM{…}.ToList继续查询