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>

最新文章

  1. 【Android端 APP 内存分析】使用工具进行APP的内存分析
  2. [emacs] Drawing uml under emacs org-mode using plantUML - 类图
  3. $("").click与onclick的区别示例介绍
  4. 遍历Map的两种方法(有排序)
  5. 每天一个linux命令(4):mkdir命令
  6. spring(3) JDBC
  7. jquery网址
  8. mustache.js渲染带事件的模板
  9. ECSHOP模糊分词搜索和商品列表关键字飘红功能
  10. C#实现汉诺塔问题
  11. mysql添加用户权限
  12. 实验四:使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用
  13. jQuery渐变弹出层
  14. 解决win10客户机本地账户登陆导致远程桌面没法访问问题
  15. 有关ArrayList常用方法的源码解析
  16. lodash源码分析之chunk的尺与刀
  17. fread和fwrite的使用
  18. 18 徐州 M
  19. 用itext合并多个pdf文件【转】【补】
  20. Linux内核分析第一次学习报告

热门文章

  1. win7 tomcat
  2. ubuntu下安装fiddler
  3. typedef函数指针那些事
  4. freebsd安装和图形界面安装
  5. qt编程有何替代品(没见过cairo graphics)
  6. SQL Server 2005中的分区表(五):添加一个分区
  7. grok 官方文档
  8. Linux系统维护修复模式
  9. 用试探回溯法解决N皇后问题
  10. Count Primes 解答