sql >> データベース >  >> RDS >> Oracle

OracleのSQLServerAPPLYに相当するものは何ですか?

    OracleのAPPLY句に相当するものは、ラテラルJOINと呼ばれていると思います。 Oracleでの横方向結合とは、行を出力する関数Fを使用してテーブルAを結合し、この関数がパラメータとしてAの列を持っている場合です。

    この設定で小さな例を作成しましょう:

    SQL> CREATE OR REPLACE TYPE emp_row AS OBJECT (
      2     empno NUMBER(4),
      3     ename VARCHAR(10),
      4     job VARCHAR(9),
      5     deptno NUMBER(2)
      6  );
      7  /
    
    Type created
    SQL> CREATE OR REPLACE TYPE emp_tab AS TABLE OF emp_row;
      2  /
    
    Type created
    SQL> CREATE OR REPLACE FUNCTION get_emp_dept(p_deptno NUMBER) RETURN emp_tab IS
      2     l_result emp_tab;
      3  BEGIN
      4     SELECT emp_row(empno, ename, job, deptno)
      5       BULK COLLECT INTO l_result
      6       FROM emp
      7      WHERE deptno = p_deptno;
      8     RETURN l_result;
      9  END get_emp_dept;
     10  /
    
    Function created
    

    Oracleでは横方向の結合は自動的に行われます。特別なキーワードはありません:

    SQL> SELECT dept.dname, emp.empno, emp.ename, emp.job
      2    FROM dept
      3   CROSS JOIN TABLE(get_emp_dept(dept.deptno)) emp;
    
    DNAME          EMPNO ENAME      JOB
    -------------- ----- ---------- ---------
    ACCOUNTING      7782 CLARK      MANAGER
    ACCOUNTING      7839 KING       PRESIDENT
    ACCOUNTING      7934 MILLER     CLERK
    RESEARCH        7369 SMITH      CLERK
    RESEARCH        7566 JONES      MANAGER
    RESEARCH        7788 SCOTT      ANALYST
    RESEARCH        7876 ADAMS      CLERK
    RESEARCH        7902 FORD       ANALYST
    SALES           7499 ALLEN      SALESMAN
    SALES           7521 WARD       SALESMAN
    SALES           7654 MARTIN     SALESMAN
    SALES           7698 BLAKE      MANAGER
    SALES           7844 TURNER     SALESMAN
    SALES           7900 JAMES      CLERK
    
    14 rows selected
    


    1. SQLServerのCROSSAPPLYに類似したPostgres

    2. コードを記述せずにODBC接続属性を設定する

    3. Oracle:OALL8は一貫性のない状態にあります

    4. Oracleでユーザーを作成して権限を付与する方法