select d.Name Department, e.Name Employee, e.Salary from Employee e join Department d on e.DepartmentId=d.Id
where 3 > (select count(distinct(Salary)) from Employee ee where ee.DepartmentId=e.DepartmentId and Salary>e.Salary)
order by d.Id, e.Salary desc;
select d.Name Department, e.Name Employee, e.Salary from Employee e join Department d on e.DepartmentId=d.Id
where e.Salary = (select max(Salary) from Employee ee where ee.DepartmentId=e.DepartmentId);
mock
create table Employee(Id int, Name varchar(9),Salary int,DepartmentId int);
create table Department(Id int,Name varchar(9));
insert into Employee values(1,'joe',7,1),(2,'henry',8,2),(3,'sam',6,2),(4,'max',9,1);
insert into Department values(1,'it'),(2,'sales');
select Name Customers from Customers c left join Orders o on c.Id=CustomerId where o.Id is null;
select Email from Person group by Email having count(*) > 1;
select distinct Num from (
select Num, if(Num=@last, @cnt:=@cnt+1, @cnt:=1) as cnt, @last:=Num from Logs, (select @last:=-1, @cnt:=0) _t
) _t where cnt >= 3;
select s.Score, (select count(*)+1 from (select distinct Score from Scores) ss where Score > s.Score) rank from Scores s order by Score desc;
create function getNthHighestSalary(N int) returns int
begin
declare M int;
set M = N - 1;
return (
select distinct Salary from Employee order by Salary desc limit M, 1
);
end
select max(Salary) from Employee where Salary < (select max(Salary) from Employee);
select FirstName,LastName,City,State from Person as p left join Address as a on p.PersonId=a.PersonId;