当前位置:网站首页> 在Oracle表中进行关键词搜索的过程
在Oracle表中进行关键词搜索的过程
2022-06-10 20:29:00 【1024问】
在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
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%'*/结果部分。如果我们搜索的关键词/文本在相关的表中找到了,找到的表的名称和找到的列的名称,数量,以及查询信息都会被写出来。
在底部是一般的总信息。我们可以看到搜索到的表的总数以及这些表中有多少被找到。
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 : 4oracle, plsql, oracle数据库, oracle表, 关键字搜索
DZone贡献者所表达的观点属于他们自己。
到此这篇关于在Oracle表中进行关键词搜索的过程的文章就介绍到这了,更多相关Oracle关键词搜索内容请搜索软件开发网以前的文章或继续浏览下面的相关文章希望大家以后多多支持软件开发网!
边栏推荐
- 蛮力法/1~n的全排列 v3 递归
- Theoretical basis of distributed services
- 用一个性能提升了666倍的小案例说明在TiDB中正确使用索引的重要性
- Meetup预告:Linkis新版本介绍以及DSS的应用实践
- Naturalspeech model synthetic speech achieves human speech level for the first time in CMOS test
- 自制Table錶格
- Unity analyzes the rendering of built-in terrain and does some interesting things
- Use DAP link to download the executable file separately to the mm32f5 microcontroller
- Leetcode advanced road - plus one
- C language ---6 first knowledge of selection statement, loop statement, function and array
猜你喜欢

信号与系统复习1

C language ---9 first knowledge of macros and pointers

简解深度学习Attention

Which city should I go to after I graduate from it? Which position has a high salary? Which companies have good treatment?

关于type-c

微积分复习1

C language -- 8 familiar keywords

A small case with 666 times performance improvement illustrates the importance of using indexes correctly in tidb

Standard dual airbags, starting from 48900 for butcher Chang'an Lumin

Fast Planner - detailed explanation of kinetic astar
随机推荐
LeetCode 进阶之路 - 字符串中的第一个唯一字符
Identity and access management (IAM)
Mysql之将查询结果插入到其它表中
C language learning review -- 1 basic knowledge review
What do software test engineers do?
Factory and strategy mode implementation scheme of coupons
Will your company choose to develop data center?
获取的网络时间 + 时区(+8)
蛮力法/任务分配
Qingniao Changping campus of Peking University: can I learn UI with a high school degree?
在手机上买基金安全吗?会不会被吞本金?
shell实现ssh登录并执行命令
Redis缓存雪崩
Theoretical basis of distributed services
自制Table錶格
Codeforces Round #798 (Div. 2)
Junior high school graduates who choose secondary vocational schools can also be promoted to institutions of higher learning
C language -- 8 familiar keywords
Nodejs: official document 3 Dgram stream
学IT毕业后该去哪个城市?哪个岗位薪资高?哪些公司待遇好?