Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/84.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/oracle/10.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/ant/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
SQL错误-“;定义不明确的列“;_Sql_Oracle - Fatal编程技术网

SQL错误-“;定义不明确的列“;

SQL错误-“;定义不明确的列“;,sql,oracle,Sql,Oracle,我试图从两个表中查询数据,并不断得到一个“定义不清的列”错误 我的查询如下所示: SELECT deptno AS "Dept No", dname AS "Dept Name", sum(sal) AS "Sal Cost" FROM emp, dept WHERE emp.deptno = dept.deptno GROUP BY dname; select语句中出现错误。每当查询中有多个表引用时,应始终限定所有列名。然后,您将再也不会出现此错误: SELECT d.deptno A

我试图从两个表中查询数据,并不断得到一个“定义不清的列”错误

我的查询如下所示:

SELECT deptno AS "Dept No", dname AS "Dept Name", sum(sal) AS "Sal Cost" 
FROM emp, dept 
WHERE emp.deptno = dept.deptno 
GROUP BY dname;

select语句中出现错误。

每当查询中有多个表引用时,应始终限定所有列名。然后,您将再也不会出现此错误:

SELECT d.deptno AS "Dept No", d.dname AS "Dept Name", sum(e.sal) AS "Sal Cost" 
FROM emp e JOIN
     dept d
     ON e.deptno = d.deptno 
GROUP BY d.deptno, d.dname;
请注意,您必须按
选择中的所有未聚合列进行聚合

我还强烈建议您使用不需要转义的列名:

SELECT d.deptno, d.dname, sum(e.sal) AS salary_cost
. . .

两个表中都定义了deptno。您需要在select子句中指定该列来自哪个表。emp或dept。列名不需要转义。这只是别名,这对于使快捷方式名称更具可读性是完全有效的。啊,我明白了。谢谢你的快速回复。前面的错误消失了,但是我现在在第一行得到另一个错误,“不是一个groupby表达式”。我觉得每当我试图使用一个包含两列以上的GROUPBY时,我经常会遇到这个错误。啊哈!我得到了它。选择d.deptno,d.dname,sum(e.sal)作为emp e JOIN dept d ON e.deptno=d.deptno GROUP BY d.dname,d.deptno的薪资成本;再次感谢!