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

変数を使用した動的クエリでIN句をどのように指定しますか?

    @Sathyaリンクのように、VARRAYをバインドできます(@Codoの例を取り上げました):

    CREATE OR REPLACE TYPE str_tab_type IS VARRAY(10) OF VARCHAR2(200);
    /
    DECLARE
      l_str_tab str_tab_type;
      l_count NUMBER;
      v_sql varchar2(3000);
    BEGIN
      l_str_tab := str_tab_type();
      l_str_tab.extend(2);
      l_str_tab(1) := 'TABLE';
      l_str_tab(2) := 'INDEX';
    
      v_sql := 'SELECT COUNT(*) FROM all_objects WHERE object_type IN (SELECT COLUMN_VALUE FROM TABLE(:v_list))';
    
      execute immediate v_sql into l_count using l_str_tab;
    
      dbms_output.put_line(l_count);
    END;
    /
    

    更新: 最初のコマンドは次のように置き換えることができます:

    CREATE OR REPLACE TYPE str_tab_type IS TABLE OF VARCHAR2(200);
        /
    

    次に電話します:

    l_str_tab.extend(1);
    

    値を追加するときはいつでも



    1. MariaDB JSON_CONTAINS_PATH()の説明

    2. PHPとMySQLを使用したUnicode文字列(हिन्दी)の保存と表示

    3. MySQLでのOCT()関数のしくみ

    4. 別のユーザーのテーブルから列名を照会する