Oracle
 sql >> база данни >  >> RDS >> Oracle

SQL не разпознава псевдоним на колона в клаузата where

Може да се използва псевдоним в списък за избор на заявка, за да се даде различно име на колона. Можете да използвате псевдонима в клаузи GROUP BY, ORDER BY или HAVING за препратка към колоната.

Стандартният SQL забранява препратките към псевдоними на колони в клауза WHERE. Това ограничение е наложено, защото когато се оценява клаузата WHERE, стойността на колоната може още да не е определена.

Така че следната заявка е незаконна:

SQL> SELECT empno AS employee, deptno AS department, sal AS salary
  2  FROM emp
  3  WHERE employee = 7369;
WHERE employee = 7369
      *
ERROR at line 3:
ORA-00904: "EMPLOYEE": invalid identifier


SQL>

Псевдонимът на колоната е разрешен в:

  • ГРУПИРАНЕ ПО
  • ПОРЪЧАЙТЕ ОТ
  • ИМАНЕ

Можете да се обърнете към псевдонима на колоната в клаузата WHERE в следните случаи:

  1. Подзаявка
  2. Общ израз на таблица (CTE)

Например,

SQL> SELECT * FROM
  2  (
  3  SELECT empno AS employee, deptno AS department, sal AS salary
  4  FROM emp
  5  )
  6  WHERE employee = 7369;

  EMPLOYEE DEPARTMENT     SALARY
---------- ---------- ----------
      7369         20        800

SQL> WITH DATA AS(
  2  SELECT empno AS employee, deptno AS department, sal AS salary
  3  FROM emp
  4  )
  5  SELECT * FROM DATA
  6  WHERE employee = 7369;

  EMPLOYEE DEPARTMENT     SALARY
---------- ---------- ----------
      7369         20        800

SQL>


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Функция TO_TIMESTAMP() в Oracle

  2. Пример за съхранена процедура в Oracle с параметър IN OUT

  3. Групиране на записи час по час или ден след ден и запълване на празнини с нула или нула

  4. Как мога да ускоря row_number в Oracle?

  5. Списък на елементите на числовия формат в Oracle