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

ストアドプロシージャ/関数はテーブルを返すことができますか?

    今のところ、これは不可能です。

    これがドキュメントです。 FROMで使用できるものについて 条項:

    table_references:
        table_reference [, table_reference] ...
    
    table_reference:
        table_factor
      | join_table
    
    table_factor:
        tbl_name [[AS] alias] [index_hint)]
      | table_subquery [AS] alias
      | ( table_references )
      | { OJ table_reference LEFT OUTER JOIN table_reference
            ON conditional_expr }
    
    join_table:
        table_reference [INNER | CROSS] JOIN table_factor [join_condition]
      | table_reference STRAIGHT_JOIN table_factor
      | table_reference STRAIGHT_JOIN table_factor ON conditional_expr
      | table_reference {LEFT|RIGHT} [OUTER] JOIN table_reference join_condition
      | table_reference NATURAL [{LEFT|RIGHT} [OUTER]] JOIN table_factor
    
    join_condition:
        ON conditional_expr
      | USING (column_list)
    
    index_hint:
        USE {INDEX|KEY} [FOR JOIN] (index_list)
      | IGNORE {INDEX|KEY} [FOR JOIN] (index_list)
      | FORCE {INDEX|KEY} [FOR JOIN] (index_list)
    
    index_list:
        index_name [, index_name] ...
    

    ご覧のとおり、ストアドプロシージャはこのリストに含まれていません。



    1. 指定されたグループごとにn個のランダムな行を選択します

    2. データベースの増分変更の検出(OracleからMongoDB ETLへ)

    3. Oracleはselectからより多くの列を持つテーブルに挿入します

    4. テーブルにない値をリストから選択します