事情是這樣的,我有三張表,用戶_角色關系表User_Role,角色_菜單關系表Role_Menu和菜單表
Menu,這三個表之間有如下關系:
User_Role=>RoleId=>RoleMenu
RoleMenu=>MenuId=>Menu
它們之間的業務關系是:
當用戶登陸后,通過UserId得到User_Role列表,將用戶所包括的角色得出
通過User_Role找到所有對應Menu
現在有個問題,就是一個用戶可以有多少角色,一個角色有多個菜單,當然,兩個不同的角色可以有相當的菜單項,這時,就出現一個問題,用戶在“管理員”這個角色里有“文件”這個菜單,同時它在“新聞管理員”這個角色里也有“文件”這個菜單,這樣返回就會出現兩個完成相同的”文件“菜單,下面,我使用匿名類和distinct方法來解決這個問題,代碼如下:
代碼如下:
class Program
{
static void Main(string[] args)
{
#region 實體列表初始化
List userRole = new List
{
new User_Role(“01”,1),
new User_Role(“01”,2),
new User_Role(“02”,1),
};
List roleMenu = new List
{
new Role_Menu(2,3),
new Role_Menu(1,1),
new Role_Menu(1,2),
new Role_Menu(2,1),
new Role_Menu(2,2),
};
List