[asp.net]填充 Gridview 使用 LINQ 到数据集查询与别名

标签: Asp.net Linq C#
发布时间: 2017/3/26 2:42:55
注意事项: 本文中文内容可能为机器翻译,如要查看英文原文请点击上面连接.

我得到下列错误。

在所选的数据源上未找到字段或属性的名称 P_ID。

我想要将绑定 Gridview 使用 LINQDataSet 。我有三张表,我要他们从中 ID's 。在查询中,使用了别名,但它给了我错误,因为找不到别名。

这是我的代码

string filterSO = "SELECT " +
                         "P.ID AS P_ID, " +
                         "S.ID AS S_ID, " +                             
                         " RS.LASTNAMER | | ' ' | | RS.FIRSTNAMER AS ReferentName, " +
                         " RS.ID," +
                         " P.STATUSP" +
                        " FROM PLANNING P," +
                         " SHIPPING S," +                            
                         " REFERENT_SHIPPING RS" +                             
                       " WHERE S.ID_REFERENT = RS.ID(+)" +
                       " AND S.ID_PLANNING = P.ID" +
                       " ORDER BY P.ID DESC";
    using (OracleConnection con = new OracleConnection(ConfigurationManager.ConnectionStrings["DBCS"].ToString()))
    {
        con.Open();
        OracleCommand cmd = new OracleCommand(filterSO, con);
        OracleDataAdapter da = new OracleDataAdapter(cmd);
        DataSet dss = new DataSet();
        da.Fill(dss, "office_all");
        Session["DATASET"] = dss;

        var officee_all = from xx in dss.Tables["office_all"].AsEnumerable()
                      select new guards
                      {
                          ID = Convert.ToInt32(xx["P_ID"]),
                          ID_S = Convert.ToInt32(xx["S_ID"]),                           

                          LASTNAME_R = xx["LASTNAMER"].ToString(),
                          FIRSTNAME_R = xx["ReferentName"].ToString(),
                          ID_R = Convert.ToInt32(xx["ID"]),
                          STATUSP = xx["STATUSP"].ToString()
                      };

        GridViewSOFirst.DataSource = officee_all.ToList();
        GridViewSOFirst.DataBind();

解决方法 1:

所选的数据源上未找到字段或属性的名称 P_ID

该消息是不言自明,此属性不可用在类中使用过,但显然你正试图绑定到此属性。

因为你在 sql 查询中选择此列,但是将它分配给属性 ID 你应该改为绑定到该属性。

ID = Convert.ToInt32(xx["P_ID"])

边注︰ 您可以使用原义字符串,这使得它更容易在 C# 中编写一个 sql 查询。我也建议使用真实/ansi 联接。甚至"Oracle 建议你使用 FROM 子句外层 JOIN 语法,而不是 Oracle join 运算符"链接

string filterSO = @"SELECT
                     P.ID AS P_ID,
                     S.ID AS S_ID,
                     RS.LASTNAMER | | ' ' | | RS.FIRSTNAMER AS ReferentName, 
                     RS.ID,
                     P.STATUSP
                    FROM PLANNING P,
                     SHIPPING S,
                     REFERENT_SHIPPING RS
                   WHERE S.ID_REFERENT = RS.ID(+)
                   AND S.ID_PLANNING = P.ID
                   ORDER BY P.ID DESC";
赞助商