init-platformmanager.sql 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. -- 创建消息表
  2. drop table lucene$message;
  3. create table lucene$message(
  4. me_id number generated always as identity(start with 1 increment by 1) primary key,
  5. me_table_name varchar(64) not null,
  6. me_method_type varchar(6) not null,
  7. me_data_id number not null,
  8. me_data varchar(1024),
  9. me_priority number(2) default 0,
  10. me_retry_count number(1) default 0,
  11. me_create_time date not null
  12. );
  13. -- 创建消息历史表
  14. drop table lucene$message_history;
  15. create table lucene$message_history(
  16. mh_id number generated always as identity(start with 1 increment by 1) primary key,
  17. mh_dequeue_time date not null,
  18. me_id number not null,
  19. me_table_name varchar(64) not null,
  20. me_method_type varchar(6) not null,
  21. me_data_id number not null,
  22. me_data varchar(1024),
  23. me_priority number(2) default 0,
  24. me_create_time date not null
  25. );
  26. -- 创建存储过程 入队消息
  27. create or replace procedure enqueue_lucene_message(v_table_name in varchar, v_method_type in varchar, v_data_id in number, v_data in varchar, v_priority in number) is
  28. begin
  29. insert into lucene$message (me_table_name, me_method_type, me_data_id, me_data, me_priority, me_create_time) values(v_table_name, v_method_type, v_data_id, v_data, v_priority, sysdate());
  30. end enqueue_lucene_message;
  31. -- 创建存储过程 出队消息
  32. create procedure dequeue_lucene_message(v_id in number) is
  33. begin
  34. insert into lucene$message_history (mh_dequeue_time, me_id, me_table_name, me_method_type, me_data_id, me_data, me_priority, me_create_time) select sysdate(), me_id, me_table_name, me_method_type, me_data_id, me_data, me_priority, me_create_time from lucene$message where me_id = v_id;
  35. delete from lucene$message where me_id = v_id;
  36. end dequeue_lucene_message;
  37. -- ----------------------------
  38. -- Triggers structure for table PURC$CHANGES
  39. -- ----------------------------
  40. CREATE or replace trigger lucene_purc_changes
  41. after insert or update of name, shortname, id, industry, adminname, profession, tags or delete on AC$US$DETAIL
  42. for each row
  43. declare
  44. v_table_name varchar(64) default 'PURC$CHANGES';
  45. v_method_type varchar(6) default 'insert';
  46. v_data_id number;
  47. v_data varchar(1024) default null;
  48. v_priority number(2) default 1;
  49. begin
  50. if inserting then
  51. v_data_id := :new.id;
  52. elsif updating then
  53. v_data_id := :old.id;
  54. elsif deleting then
  55. v_data_id := :old.id;
  56. end if;
  57. enqueue_lucene_message(v_table_name, v_method_type, v_data_id, v_data, v_priority);
  58. end;