在Oracle表中进行关键词搜索的过程

目录

  • 在Oracle表中的关键词搜索
    • 在Oracle数据库中,我们可以很容易地在模式内的表中找到我们正在寻找的文本或关键词。
  • 结果部分。

    在Oracle表中的关键词搜索
    在Oracle数据库中,我们可以很容易地在模式内的表中找到我们正在寻找的文本或关键词。
    【在Oracle表中进行关键词搜索的过程】请阅读以了解该过程的步骤。
    在Oracle数据库中,我们可以很容易地在模式内的表中找到我们要找的文本或关键词。由于我们可以搜索模式中的所有表,我们也可以在属于该模式的所需表内进行搜索。
    如下面的PL/SQL块所示,我们要搜索的文本/关键词是在相关表的varchar列上进行的。
    • 首先,我们在PL/SQL代码块的DECLARATION部分指定 "p_search_text" -->要搜索的常量文本。
    • 在最下面一行,我们指定SCHEMA NAME为一个常量。
    • 在下一行中,我们指定了TABLE NAME。
    • 当我们把TABLE NAME字段传递为空时,我们搜索该模式中的所有表。
    • 如果我们把TABLE NAME传满,我们应该注意该模式中的表。否则,我们的搜索将找不到任何记录。
    如上所述输入我们的定义后,我们可以通过Oracle SQL Developer或Toad运行下面的PL/SQL块。
    PLSQL
    DECLAREp_search_textCONSTANT VARCHAR2 (1000) := 'SAMPLE SEARCH WRITE'; p_schema_nameCONSTANT VARCHAR2 (1000) := 'SAMPLE SCHEMA NAME'; p_table_nameCONSTANT VARCHAR2 (1000) := 'SAMPLE TABLE NAME'; -- NULL (If FULL will work, give the table name null)TYPE r_column_data IS RECORD(column_nameSYS.DBA_TAB_COLUMNS.COLUMN_NAME%TYPE); TYPE tr_column_data IS TABLE OF r_column_dataINDEX BY PLS_INTEGER; ltr_column_datatr_column_data; TYPE tr_table IS TABLE OF VARCHAR2 (200)INDEX BY PLS_INTEGER; l_sqlVARCHAR2 (1000); l_countNUMBER; ltr_tabletr_table; l_foundNUMBER := 0; l_column_nameVARCHAR2 (100); BEGINSELECT table_nameBULK COLLECT INTO ltr_tableFROM dba_tablesWHEREowner = p_schema_nameAND table_name LIKE '' || p_table_name || '' || '%'AND ROWNUM <= 19999ORDER BY 1; DBMS_APPLICATION_INFO.set_module ('PV_FINDER', NULL); FOR i IN 1 .. ltr_table.COUNTLOOPDBMS_APPLICATION_INFO.set_client_info (i || '/' || ltr_table.COUNT || ' -> ' || ltr_table (i)); SELECT col.column_nameBULK COLLECT INTO ltr_column_dataFROM sys.dba_tab_columns colINNER JOIN sys.dba_tables tON col.owner = t.owner AND col.table_name = t.table_nameWHERE col.table_name = ltr_table (i) AND col.DATA_TYPE = 'VARCHAR2'ORDER BY col.column_id; FOR j IN 1 .. ltr_column_data.COUNTLOOPDBMS_APPLICATION_INFO.set_client_info (j|| '/'|| ltr_column_data.COUNT|| ' -> '|| ltr_column_data (j).column_name); l_sql :='SELECT /*+ PARALLEL (A 8)*/ count(1) from '|| p_schema_name|| '.'|| ltr_table (i)|| ' A WHERE '|| ltr_column_data (j).column_name|| ' ='''|| p_search_text|| ''''; EXECUTE IMMEDIATE l_sql INTO l_count; IF l_count > 0THENIF l_found = 0THENDBMS_OUTPUT.put_line ('Search Keyword: ' || p_search_text); DBMS_OUTPUT.put_line ('-------------------------------------------'); END IF; DBMS_OUTPUT.put_line ('table name found : '||ltr_table (i) ); DBMS_OUTPUT.put_line ('column name found : ' || ltr_column_data (j).column_name); DBMS_OUTPUT.put_line ('count : ' || l_count); DBMS_OUTPUT.put_line ('sql name : ' || l_sql); DBMS_OUTPUT.put_line ('*****'); l_found := l_found + 1; END IF; END LOOP; END LOOP; DBMS_APPLICATION_INFO.set_module (NULL, NULL); DBMS_APPLICATION_INFO.set_client_info (NULL); DBMS_OUTPUT.put_line ('-------------------------------------------'); DBMS_OUTPUT.put_line ('total number of tables searched : ' || ltr_table.COUNT); DBMS_OUTPUT.put_line ('total number of tables found : ' || l_found); END; /*select module,client_info from v$session where module like '%PV_FINDER%'*/


    结果部分。
    • 如果我们搜索的关键词/文本在相关的表中找到了,找到的表的名称和找到的列的名称,数量,以及查询信息都会被写出来。
    • 在底部是一般的总信息。我们可以看到搜索到的表的总数以及这些表中有多少被找到。
    Search Keyword: SAMPLE SEARCH KEYWORD-------------------------------------------table name found : TABLE - 1column name found : COLUMN NAME count : 4sql name : SELECT /*+ PARALLEL (A 8)*/ count(1) from SCHEMA_NAME.TABLE-1 A WHERE TABLE-1.COLUMN ='SAMPLE SEARCH KEYWORD'*****table name found : TABLE - 2column name found : COLUMN NAME count : 2sql name : SELECT /*+ PARALLEL (A 8)*/ count(1) from SCHEMA_NAME.TABLE-2 A WHERE TABLE-1.COLUMN ='SAMPLE SEARCH KEYWORD'*****table name found : TABLE - 3column name found : COLUMN NAME count : 2sql name : SELECT /*+ PARALLEL (A 8)*/ count(1) from SCHEMA_NAME.TABLE-3 A WHERE TABLE-1.COLUMN ='SAMPLE SEARCH KEYWORD'*****table name found : TABLE - 4column name found : COLUMN NAME count : 2sql name : SELECT /*+ PARALLEL (A 8)*/ count(1) from SCHEMA_NAME.TABLE-4 A WHERE TABLE-1.COLUMN ='SAMPLE SEARCH KEYWORD'*****-------------------------------------------total number of tables searched : 72total number of tables found : 4

    oracle, plsql, oracle数据库, oracle表, 关键字搜索
    DZone贡献者所表达的观点属于他们自己。
    到此这篇关于在Oracle表中进行关键词搜索的过程的文章就介绍到这了,更多相关Oracle关键词搜索内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

      推荐阅读