oracle全文检索笔记
1、删除词法解析器
exec ctx_ddl.drop_preference('my_lexer');
2、创建中文词法解析器
exec ctx_ddl.create_preference ('my_lexer', 'chinese_vgram_lexer');
3、创建全文索引,多字段
EXEC ctx_ddl.create_preference('ctx_idx_jdw_person_pref','MULTI_COLUMN_DATASTORE');
EXEC ctx_ddl.set_attribute('ctx_idx_jdw_person_pref ','columns','name,address');
CREATE INDEX ctx_idx_jdw_person ON jdw_person(name) INDEXTYPE IS ctxsys.CONTEXT PARAMETERS('DATASTORE ctx_idx_jdw_person_pref lexer my_lexer');
4、切词
exec CTX_DDL.CREATE_POLICY('MY_POLICY', LEXER => 'my_lexer');
create or replace function p_split_chinese(p_input in varchar2)
return varchar2 as
v_tab CTX_DOC.TOKEN_TAB;
v_return VARCHAR2(323767);
begin
CTX_DOC.POLICY_TOKENS('my_policy',p_input,v_tab);
for i in 1..v_tab.count loop
v_return := v_return || ',' || v_tab(i).token;
end loop;
return LTRIM(v_return,',');
end;
/
5、同步及优化
exec ctx_ddl.sync_index('ctx_idx_jdw_person');
exec ctx_ddl.optimize_index('ctx_idx_jdw_person', 'full');
6、创建定时任务,定期优化和同步域索引
SQL> create or replace procedure hsp_sync_index as
2 begin
3 ctx_ddl.sync_index('id_cont_msg');
4 end;
5 /
Procedure created.
Elapsed: 00:00:00.08
SQL> VARIABLE jobno number;
SQL> BEGIN
2 DBMS_JOB.SUBMIT(:jobno,'hsp_sync_index();',
3 SYSDATE, 'SYSDATE + (1/24/4)');
4 commit;
5 END;
6 /
PL/SQL procedure successfully completed.
Elapsed: 00:00:00.27
SQL> create or replace procedure hsp_optimize_index as
2 begin
3 ctx_ddl.optimize_index('id_cont_msg','FULL');
4 end;
5 /
SQL> VARIABLE jobno number;
SQL> BEGIN
2 DBMS_JOB.SUBMIT(:jobno,'hsp_optimize_index();',
3 SYSDATE, 'SYSDATE + 1');
4 commit;
5 END;
6 /
Procedure created.
Elapsed: 00:00:00.03
PL/SQL procedure successfully completed.
Elapsed: 00:00:00.02
SQL>
最新文章
- 【Android端 APP 内存分析】使用工具进行APP的内存分析
- [emacs] Drawing uml under emacs org-mode using plantUML - 类图
- $(";";).click与onclick的区别示例介绍
- 遍历Map的两种方法(有排序)
- 每天一个linux命令(4):mkdir命令
- spring(3) JDBC
- jquery网址
- mustache.js渲染带事件的模板
- ECSHOP模糊分词搜索和商品列表关键字飘红功能
- C#实现汉诺塔问题
- mysql添加用户权限
- 实验四:使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用
- jQuery渐变弹出层
- 解决win10客户机本地账户登陆导致远程桌面没法访问问题
- 有关ArrayList常用方法的源码解析
- lodash源码分析之chunk的尺与刀
- fread和fwrite的使用
- 18 徐州 M
- 用itext合并多个pdf文件【转】【补】
- Linux内核分析第一次学习报告