select name,date,basic,grade from employees as e inner join salary as s on e.employee_id=s.employee_id inner join wage_grade as g on s.basic between g.low and g.high where year(date)=2018 and month(date)=12 order by basic having basic <= 10000 ; ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'having basic <= 10000' at line 1
时间: 2024-02-13 16:10:05 浏览: 179
你的 SQL 语句存在语法错误,HAVING 子句应该在 GROUP BY 子句之后使用。你可以将 HAVING 子句中的条件改写为 WHERE 子句中的条件,如下所示:
```
SELECT name, date, basic, grade
FROM employees AS e
INNER JOIN salary AS s ON e.employee_id=s.employee_id
INNER JOIN wage_grade AS g ON s.basic BETWEEN g.low AND g.high
WHERE YEAR(date)=2018 AND MONTH(date)=12 AND basic <= 10000
ORDER BY basic;
```
这个 SQL 查询语句将返回符合以下条件的员工的姓名、日期、基本工资和工资等级:2018 年 12 月份的记录,基本工资不超过 10000 元,并按照基本工资从低到高排序。
相关问题
select dept_id,name,basic+bonus from salary inner join employees on salary.employee_id=employee.employee_id where dept_id=( select employee_id from employees where dept_id=( select dept_id from departments where dept_name='人事部' )) and year(date)=2018 and month(date)=12; ERROR 1054 (42S22): Unknown column 'employee.employee_id' in 'on clause'
在这个SQL语句中,出现了另一个错误,提示“Unknown column 'employee.employee_id' in 'on clause'”。这个错误通常表示在ON子句中使用了不存在的列名或表别名。在这个情况下,问题在于在ON子句中使用了employee.employee_id列,但是没有为employee表指定别名。
为了解决这个问题,需要为employee表指定一个别名,并在ON子句中使用它。下面是修正后的SQL语句:
```
select s.dept_id, e.name, s.basic+s.bonus
from salary s
inner join employees e on s.employee_id = e.employee_id
where s.dept_id = (
select employee_id from employees where dept_id = (
select dept_id from departments where dept_name = '人事部'
)
) and year(s.date) = 2018 and month(s.date) = 12;
```
在这个修正后的SQL语句中,我们为employee表指定了别名e,并在ON子句和SELECT子句中使用它。这样就能够正确地查询部门名称为“人事部”、时间为2018年12月份的员工的工资信息。
select dept_id,name,basic+bonus from salary inner join employees on salary.employee_id=employees.employee_id where dept_id=( select employee_id from employees where dept_id=( select dept_id from departments where dept_name='人事部' )) and year(date)=2018 and month(date)=12; ERROR 1242 (21000): Subquery returns more than 1 row
在这个SQL语句中,出现了错误“Subquery returns more than 1 row”,它通常表示子查询返回了多行数据。在这个情况下,问题在于第一个子查询返回了多个employee_id值,而不是单个值,因此无法将其用作外部查询中的条件。
为了解决这个问题,可以考虑使用IN运算符而不是等号来比较子查询返回的值。下面是修正后的SQL语句:
```
select s.dept_id, e.name, s.basic+s.bonus
from salary s
inner join employees e on s.employee_id = e.employee_id
where s.dept_id IN (
select employee_id from employees where dept_id = (
select dept_id from departments where dept_name = '人事部'
)
) and year(s.date) = 2018 and month(s.date) = 12;
```
在这个修正后的SQL语句中,我们使用IN运算符来比较子查询返回的值。这样就能够正确地查询部门名称为“人事部”、时间为2018年12月份的员工的工资信息。
阅读全文