WEB开发网      婵犵數濞€濞佳囧磹婵犳艾鐤炬い鎰堕檮閸嬬喐銇勯弽銊с€掗梻鍕閺岋箑螣娓氼垱笑闂佽姘﹂褔婀佸┑鐘诧工妤犲憡绂嶉崜褏纾奸弶鍫涘妼缁楁岸鏌熷畡鐗堝殗闁诡喒鏅犲畷褰掝敃閵堝棙顔忔繝鐢靛仦閸ㄥ爼骞愰幘顔肩;闁规崘绉ぐ鎺撳亹闁绘垶锕╁Λ鍕⒑閹肩偛濡奸悗娑掓櫇缁顓兼径妯绘櫇闂佹寧绻傞弻濠囨晝閸屾稓鍘甸柣搴㈢⊕閿氶柣蹇ョ稻缁绘繃绻濋崘銊т紝闂佽鍨伴崯鏉戠暦閻旂⒈鏁傞柛鈾€鏅欑槐妯衡攽閻愬樊鍤熷┑顔藉劤铻為柛鏇ㄥ墯閸欏繘鏌嶉崫鍕櫣缂佲偓婢跺绠鹃柟瀛樼箘閿涘秵顨ラ悙顏勭伈闁诡喖缍婂畷鎯邦槻婵℃彃顭烽弻娑㈠Ω閵夈儺鍔夌紓浣稿€哥粔褰掑极閹剧粯鏅搁柨鐕傛嫹 ---闂傚倷鐒︾€笛兠洪埡鍛闁跨噦鎷�
开发学院数据库MSSQL Server SQLServer如何得到用户的继承列表 阅读

SQLServer如何得到用户的继承列表

 2007-11-11 11:09:14 来源:WEB开发网 闂傚倷绶氬ḿ褍螞閹绢喖绠柨鐕傛嫹闂傚倷绀侀幉锟犲垂閻㈠灚宕查柟鎵閸庡秵銇勯幒鎴濃偓鐢稿磻閹炬枼妲堟繛鍡楃С濞岊亞绱撻崒姘扁枌闁瑰嚖鎷�婵犵數濮幏鍐川椤撴繄鎹曢梻渚€娼уú銈吤洪妸鈺佺劦妞ゆ帊鑳堕埊鏇㈡煏閸モ晛浠х紒杈╁仱閺佹捇鏁撻敓锟�闂傚倷绶氬ḿ褍螞閹绢喖绠柨鐕傛嫹  闂傚倷鑳舵灙缂佺粯顨呴埢宥夊即閵忕姵鐎梺缁樺姇閹碱偆鐥閺屾洘绻濊箛鏇犵獥闂佺厧澹婃禍婊堚€旈崘顏佸亾閿濆骸澧ù鐘欏嫮绠鹃柛顐ゅ枎閻忋儲銇勯弴妯哄姦妞ゃ垺鐟╅幃鈩冩償閵囧府鎷�
核心提示:在实际开发中,尤其是在做权限管理的时候,SQLServer如何得到用户的继承列表,常常要对对某个用户的权限进行检索,本文给出sql server(WINDOWS平台上强大的数据库平台)中的一个实例.--用户继承树CREATE function getUserTree(@UserName sysname,--用户名@Se

  在实际开发中,尤其是在做权限管理的时候,常常要对对某个用户的权限进行检索,本文给出sql server(WINDOWS平台上强大的数据库平台)中的一个实例.
  
  --用户继承树
  CREATE function getUserTree(@UserName sysname, --用户名
  @Seq bit   --查找方式:0查找子孙 1.查找祖先
  )
  returns @Result table(UserID sysname,UserName sysname,Level int)
  as
  begin
  declare @UserId sysname
  set @userId=user_id(@userName)
  
  if @userid is null
  begin
  --raiserror('指定的用户名不存在',16,1)
  return
  end
  
  DECLARE @level int, @line char(20)
  declare @stack table(item sysname, level int)
  INSERT INTO @stack VALUES (@UserID, 1)
  SELECT @level = 1
  
  WHILE @level > 0
  BEGIN
  IF EXISTS (SELECT * FROM @stack WHERE level = @level)
  BEGIN
  SELECT @userId = item
  FROM @stack
  WHERE level = @level
  insert into @Result values(@UserId,User_name(@userID),@level)
  
  DELETE FROM @stack
  WHERE level = @level
  AND item = @userId
  
  if @Seq=1 --查找祖先
  INSERT @stack
  SELECT groupuid, @level + 1
  FROM sysmembers
  WHERE memberuid = @userId
  else --查找子孙
  INSERT @stack
  SELECT memberuid, @level + 1
  FROM sysmembers
  WHERE groupuid = @userId
  
  IF @@ROWCOUNT > 0
  SELECT @level = @level + 1
  END
  ELSE
  SELECT @level = @level - 1
  END -- WHILE
  
  return
  end
  
  实例:
  exec sp_addrole 'Users'
  exec sp_addrole 'BusinessMan'
  exec sp_addrolemember 'Users','BusinessMan'
  exec sp_addrole 'Saler'
  exec sp_addrolemember 'BusinessMan','Saler'
  
  exec sp_addlogin 'OrderMan','OrderMan','lifeng'
  exec sp_addrolemember 'Saler','OrderMan'
  exec sp_grantdbaccess 'OrderMan','OrderMan'
  select * from getUserTree('OrderMan',1)
  
  结果显示
  UserID  USRENAME   Level
  5       OrderMan     1
  16402   Saler         2
  16401   BusinessMan 3
  16403   Users        4
  
  这种方法,也在MRP/ERP系统中遍历BOM时使用

Tags:SQLServer 如何 得到

编辑录入:coldstar [复制链接] [打 印]
赞助商链接