欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

在Oracle表中進行關(guān)鍵詞搜索的過程

 更新時間:2022年06月10日 15:03:27   作者:方石劍  
這篇文章主要介紹了在Oracle表中進行關(guān)鍵詞搜索的過程,我們可以通過Oracle?SQL?Developer或Toad運行PL/SQL塊,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

在Oracle表中的關(guān)鍵詞搜索

在Oracle數(shù)據(jù)庫中,我們可以很容易地在模式內(nèi)的表中找到我們正在尋找的文本或關(guān)鍵詞。

請閱讀以了解該過程的步驟。

在Oracle數(shù)據(jù)庫中,我們可以很容易地在模式內(nèi)的表中找到我們要找的文本或關(guān)鍵詞。由于我們可以搜索模式中的所有表,我們也可以在屬于該模式的所需表內(nèi)進行搜索。

如下面的PL/SQL塊所示,我們要搜索的文本/關(guān)鍵詞是在相關(guān)表的varchar列上進行的。

  • 首先,我們在PL/SQL代碼塊的DECLARATION部分指定 "p_search_text" -->要搜索的常量文本。
  • 在最下面一行,我們指定SCHEMA NAME為一個常量。
  • 在下一行中,我們指定了TABLE NAME。
  • 當我們把TABLE NAME字段傳遞為空時,我們搜索該模式中的所有表。
  • 如果我們把TABLE NAME傳滿,我們應該注意該模式中的表。否則,我們的搜索將找不到任何記錄。

如上所述輸入我們的定義后,我們可以通過Oracle SQL Developer或Toad運行下面的PL/SQL塊。

PLSQL

DECLARE
    p_search_text      CONSTANT VARCHAR2 (1000) := 'SAMPLE SEARCH WRITE';
    p_schema_name      CONSTANT VARCHAR2 (1000) := 'SAMPLE SCHEMA NAME'; 
    p_table_name       CONSTANT VARCHAR2 (1000) := 'SAMPLE TABLE NAME';-- NULL (If FULL will work, give the table name null)

    TYPE r_column_data IS RECORD
    (
        column_name    SYS.DBA_TAB_COLUMNS.COLUMN_NAME%TYPE
    );

    TYPE tr_column_data IS TABLE OF r_column_data
        INDEX BY PLS_INTEGER;

    ltr_column_data             tr_column_data;

    TYPE tr_table IS TABLE OF VARCHAR2 (200)
        INDEX BY PLS_INTEGER;

    l_sql                       VARCHAR2 (1000);
    l_count                     NUMBER;
    ltr_table                   tr_table;
    l_found                     NUMBER := 0;
    l_column_name               VARCHAR2 (100);
BEGIN
      SELECT table_name
        BULK COLLECT INTO ltr_table
        FROM dba_tables
       WHERE     owner = p_schema_name
             AND table_name LIKE '' || p_table_name || '' || '%'
             AND ROWNUM <= 19999
    ORDER BY 1;

    DBMS_APPLICATION_INFO.set_module ('PV_FINDER', NULL);

    FOR i IN 1 .. ltr_table.COUNT
    LOOP
        DBMS_APPLICATION_INFO.set_client_info (
            i || '/' || ltr_table.COUNT || ' -> ' || ltr_table (i));

          SELECT col.column_name
            BULK COLLECT INTO ltr_column_data
            FROM sys.dba_tab_columns col
                 INNER JOIN sys.dba_tables t
                     ON col.owner = t.owner AND col.table_name = t.table_name
           WHERE col.table_name = ltr_table (i) AND col.DATA_TYPE = 'VARCHAR2'
        ORDER BY col.column_id;

        FOR j IN 1 .. ltr_column_data.COUNT
        LOOP
            DBMS_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 > 0
            THEN
                IF l_found = 0
                THEN
                    DBMS_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%'*/

結(jié)果部分。

  • 如果我們搜索的關(guān)鍵詞/文本在相關(guān)的表中找到了,找到的表的名稱和找到的列的名稱,數(shù)量,以及查詢信息都會被寫出來。
  • 在底部是一般的總信息。我們可以看到搜索到的表的總數(shù)以及這些表中有多少被找到。
Search Keyword: SAMPLE SEARCH KEYWORD
-------------------------------------------
table name found : TABLE - 1
column name found : COLUMN NAME 
count : 4
sql name : SELECT /*+ PARALLEL (A 8)*/ count(1) from SCHEMA_NAME.TABLE-1 A WHERE TABLE-1.COLUMN ='SAMPLE SEARCH KEYWORD'
*****
table name found : TABLE - 2
column name found : COLUMN NAME 
count : 2
sql name : SELECT /*+ PARALLEL (A 8)*/ count(1) from SCHEMA_NAME.TABLE-2 A WHERE TABLE-1.COLUMN ='SAMPLE SEARCH KEYWORD'
*****
table name found : TABLE - 3
column name found : COLUMN NAME 
count : 2
sql name : SELECT /*+ PARALLEL (A 8)*/ count(1) from SCHEMA_NAME.TABLE-3 A WHERE TABLE-1.COLUMN ='SAMPLE SEARCH KEYWORD'
*****
table name found : TABLE - 4
column name found : COLUMN NAME 
count : 2
sql 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 : 72
total number of tables found : 4

oracle, plsql, oracle數(shù)據(jù)庫, oracle表, 關(guān)鍵字搜索

DZone貢獻者所表達的觀點屬于他們自己。

到此這篇關(guān)于在Oracle表中進行關(guān)鍵詞搜索的過程的文章就介紹到這了,更多相關(guān)Oracle關(guān)鍵詞搜索內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 關(guān)于Oracle中SqlLoader的用法

    關(guān)于Oracle中SqlLoader的用法

    這篇文章主要介紹了關(guān)于Oracle中SqlLoader的用法,sqlldr是oracle的sql*loader工具,他可以把外部的文本格式數(shù)據(jù)導入到oracle的內(nèi)部表中,適用于不同數(shù)據(jù)庫之間的數(shù)據(jù)轉(zhuǎn)化遷移,需要的朋友可以參考下
    2023-07-07
  • DBCA命令行搭建Oracle ADG的流程

    DBCA命令行搭建Oracle ADG的流程

    隨著Oracle數(shù)據(jù)庫版本的更迭,搭建備庫的方式多種多樣。今天介紹一種創(chuàng)建物理備庫的新方式,從12C版本開始推出:使用 DBCA 命令行,需要的朋友參考下吧
    2021-06-06
  • Oracle Number型的深入理解

    Oracle Number型的深入理解

    本篇文章是對Oracle中Number型進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • 詳解oracle管道函數(shù)的用法(一行拆為多行)

    詳解oracle管道函數(shù)的用法(一行拆為多行)

    這篇文章主要介紹了oracle管道函數(shù)的用法(一行拆為多行),非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08
  • [Oracle] Data Guard 之 淺析Switchover與Failover

    [Oracle] Data Guard 之 淺析Switchover與Failover

    以下是對Oracle中Switchover與Failover的使用進行了詳細的分析介紹,需要的朋友參考下
    2013-07-07
  • oracle獲取當前時間,精確到毫秒并指定精確位數(shù)的實現(xiàn)方法

    oracle獲取當前時間,精確到毫秒并指定精確位數(shù)的實現(xiàn)方法

    下面小編就為大家?guī)硪黄猳racle獲取當前時間,精確到毫秒并指定精確位數(shù)的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • Oracle中如何把表和索引放在不同的表空間里

    Oracle中如何把表和索引放在不同的表空間里

    Oracle中并沒有區(qū)分表空間里放的是表還是索引,所有當數(shù)據(jù)量比較小時,完全可以把表和索引放在同一個表空間里,但隨著數(shù)據(jù)量的增大,最好還是把表和索引分開存儲在不同的表空間里
    2013-07-07
  • Oracle LogMiner的使用實例代碼

    Oracle LogMiner的使用實例代碼

    這篇文章主要給大家分享了關(guān)于Oracle LogMiner的使用實例代碼,文中通過示例代碼介紹了關(guān)于查詢當前日志組、業(yè)務用戶插入操作、歸檔日志切換、業(yè)務用戶插入操作以及歸檔日志切換等等的相關(guān)功能,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-07-07
  • oracle10g發(fā)送email示例

    oracle10g發(fā)送email示例

    本文介紹了通過Oracle10g發(fā)送Email的實例,該Procedure支持中文郵件、HTML代碼、多收件人。 ,需要的朋友可以參考下
    2014-01-01
  • 簡述Oracle中in和exists的不同

    簡述Oracle中in和exists的不同

    大家一直認為exists比in速度快,其實是不準確的,接下來腳本之家小編給大家分享Oracle中in和exists的不同,感興趣的朋友參考下吧
    2017-09-09

最新評論