Sqlserver
 sql >> Baza danych >  >> RDS >> Sqlserver

Jak sprawdzić wzajemne istnienie pól w tej samej tabeli w dwóch kolumnach?

Czy coś takiego działa dla Ciebie:

With ManagerWorkers As
    (
    -- get managers with workers
    Select Managers.WorkerUsername As ManagerUsername, Workers.WorkerUsername
    From tblMyTable As Managers
        Join tblMyTable As Workers
            On Workers.ManagerUsername = Managers.WorkerUsername
    ) 
Select *
From ManagerWorkers
Union All
-- get workers that have a manager in the above list
Select WorkerUsername, ManagerUsername
From tblMyTable
Where Exists(   Select 1
                From ManagerWorkers
                Where ManagerWorkers.ManagerUsername = tblMyTable.ManagerUsername
                )   

EDYTUJ :Biorąc pod uwagę aktualizację pytania, co z następującym zapytaniem:

Select D1.u_username, U1.Permission, U1.Grade, D1.f_username, U2.Permission, U2.Grade
from tblDynamicUserList As D1
    Join tblDynamicUserList As D2
        On D2.u_username = D1.f_username
            And D2.f_username = D1.u_username
    Join tblUsers As U1
        On U1.u_username = D1.u_username
    Join tblUsers As U2
        On U2.u_username = D2.u_username


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Okresowe InvalidCastException i serwer nie mógł wznowić transakcji z Linq

  2. Jaka jest różnica między datą i godziną?

  3. Zalecana metoda importowania pliku .csv do programu Microsoft SQL Server 2008 R2?

  4. Przenoszenie systemowych baz danych w klastrze pracy awaryjnej programu SQL Server

  5. Jak utworzyć bazę danych online z trybu przywracania w SQL Server?