ASP.NET:模型层中某一实体类中的某…

在使用gridView的时候,如果实体类中的属性是其他一个实体类的对象,那么在gridView中要想通过"对象.属性"的方法来获得另一表中的数据,需要将这一在gridView中的列转换为TemplateField,如下
Models:
角色类
public class UserRole
    {
        public int Id { get; set; }
        public string Name { get; set; }
    }
用户类
  public class User
    {
        public int ID { get; set; }
        public string Name { get; set; }
        public UserRole UserRole { get; set; } //直接用角色类对象
    }
DAL层:
用户类:数据访问层:
  public List<User> showAll()
        {
            string sql = "SELECT ID,Name,UserRoleId FROM [USER]";
            List<User> list = new List<User>();
            DataSet ds = SqlHelper.ExecuteDataset(SqlHelper.ConnectionString, CommandType.Text, sql, null);
            foreach (DataRow dr in ds.Tables[0].Rows)
            {
                User uu = new User();
                uu.ID = Convert.ToInt32(dr["id"]);
                uu.Name = dr["Name"].ToString();
                uu.UserRole = new UserRoleDAL().SelectUserRoleById(Convert.ToInt32(dr["userroleid"])); //这里直接调用角色类中的方法:根据角色ID获得该角色类的对象,因为数据库中存放的是角色类表的主键(外键)
                list.Add(uu);
            }
            return list;
        }

最后修改页面代码:
<asp:TemplateField HeaderText="UserRole" SortExpression="UserRole">
                    <EditItemTemplate>
                        <asp:TextBox ID="TextBox1" runat="server" Text='<%# Bind("UserRole") %>'></asp:TextBox>
                    </EditItemTemplate>
                    <ItemTemplate>
                        <asp:Label ID="Label1" runat="server" 
                            Text='<%# Bind("UserRole.Name") %>'></asp:Label>     //将这里的UserRole.Name进行重新绑定
                    </ItemTemplate>
                </asp:TemplateField>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值