久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

查詢不排除具有特定權限的人

Query not excluding people with certain privilege(查詢不排除具有特定權限的人)
本文介紹了查詢不排除具有特定權限的人的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

我有這樣的數據:表 Person_by_Privileges:

<前>PersonID Last First 設施部門特權1 霍夫瑪麗 S P abc1 霍夫瑪麗 S P cde1 霍夫瑪麗 SP def2 史密斯喬治 S P abc2 Smith Georg S P cde

我試圖讓查詢只返回 Georg Smith,因為他沒有 def 的權限.我在這樣做時遇到了麻煩,因為它是不同的查詢行.我正在嘗試:

SELECT 不同的 [PersonID],[最后的],[第一的],[設施],[部門],權限=東西((SELECT ',' + pp.Privileages FROM Person_by_Privilages pp where Facility='S' FOR XML PATH ('')), 1, 1, '')來自 [Person_by_Privileges] pp在哪里設施='S'和(部門喜歡 ('%p%'))和不喜歡的權限 ('%def%')

但是當我查看該查詢的第一個人 (Hoff) 時,不應返回該信息,因為他們確實擁有 def 的權限,我確實在結果中找到了該人:

PersonID Last First Facility Dept 特權1 Hoff Mary SP(她的特權列表附加在一起......確實包括def)

解決方案

您想顯示用戶行,前提是不存在具有定義權限的行.類似的東西

SELECT personid、last、first、facility、department、...FROM person_by_privilages ppWHERE 設施 = 'S'AND 部門喜歡 ('%P%')并且不存在(選擇 *來自 person_by_privilages pp2哪里 pp2.personid = pp.personidAND pp2.facility = 'S'AND pp2.department like ('%P%')AND pp2.privilages LIKE ('%def%'));

I have data like this: table Person_by_Privileges:

PersonID Last  First Facility Department Privilages
1        Hoff  Mary  S        P          abc
1        Hoff  Mary  S        P          cde
1        Hoff  Mary  S        P          def
2        Smith Georg S        P          abc
2        Smith Georg S        P          cde

I'm trying to get the query to only return Georg Smith, since he doesn't have Privilege for def. I'm having trouble doing that, since it's different query lines. I'm trying this:

SELECT distinct [PersonID]
      ,[Last]
      ,[First]
      ,[Facility]
      ,[Department]
      ,Privilages = STUFF(
                 (SELECT ',' + pp.Privilages FROM Person_by_Privilages pp where Facility='S' FOR XML PATH ('')), 1, 1, ''
               ) 
  FROM [Person_by_Privilages] pp  
  where
  Facility='S'
  AND
  (
     Department like ('%p%')
  )
  and 
  Privilages NOT LIKE ('%def%')

But when I look at the first person (Hoff) for that query, that shouldn't be returned because they do have Privilage for def, I do get that person in the results:

PersonID Last First Facility Dept Privilages
1        Hoff Mary  S        P    (list of her Privilages appended together..does include the def)

解決方案

You want to show a users rows, provided there does not exist a row with a def privilege. Something like

SELECT personid, last, first, facility, department, ...
FROM person_by_privilages pp
WHERE facility = 'S'
AND department like ('%P%')
AND NOT EXISTS
(
  SELECT *
  FROM person_by_privilages pp2
  WHERE pp2.personid = pp.personid
  AND pp2.facility = 'S'
  AND pp2.department like ('%P%')
  AND pp2.privilages LIKE ('%def%')
);

這篇關于查詢不排除具有特定權限的人的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

相關文檔推薦

Converting Every Child Tags in to a Single Column with multiple Delimiters -SQL Server (3)(將每個子標記轉換為具有多個分隔符的單列-SQL Server (3))
How can I create a view from more than one table?(如何從多個表創建視圖?)
Create calculated value based on calculated value inside previous row(根據前一行內的計算值創建計算值)
How do I stack the first two columns of a table into a single column, but also pair third column with the first column only?(如何將表格的前兩列堆疊成一列,但也僅將第三列與第一列配對?) - IT屋-程序員軟件開發技
Recursive t-sql query(遞歸 t-sql 查詢)
Convert Month Name to Date / Month Number (Combinations of Questions amp; Answers)(將月份名稱轉換為日期/月份編號(問題和答案的組合))
主站蜘蛛池模板: 日韩精品视频一区二区三区 | 亚洲综合三区 | 日韩一区二区三区视频 | 九九99久久 | 亚洲欧美精品国产一级在线 | 日韩精品一区二区三区 | 热久久国产 | 五月婷婷在线播放 | 大陆一级毛片免费视频观看 | 亚洲一区二区视频在线观看 | 先锋影音资源网站 | 91精品国产一区二区三区 | 日韩欧美精品一区 | 看片91 | 日韩在线一区二区三区 | 欧美日韩综合 | 欧美日韩综合一区 | 久久夜视频 | 欧美美女爱爱视频 | 九一在线| 四虎午夜剧场 | 91精品久久久久久久久99蜜臂 | 91麻豆精品国产91久久久久久久久 | 在线观看精品 | 91精品国产综合久久香蕉麻豆 | 精品区一区二区 | 一区在线视频 | 国产亚洲精品精品国产亚洲综合 | 中文字幕人成人 | 久久久成人免费视频 | 国产一区二区三区在线 | 久久国产一区二区三区 | 精品一区二区久久久久久久网站 | 久久国产区 | www.9191.com| 精品国产一区二区三区性色av | 中文字幕一区二区三区精彩视频 | 中文字幕日韩一区 | 久久精品免费一区二区三 | 亚洲国产精品一区二区三区 | 成人综合久久 |