在使用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>