init_mock.sql 141 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932
  1. -- ============================================================
  2. -- 灵越智报 2.0 - 数据库初始化 & Mock数据
  3. -- 场景: 成都院-安全生产标准化复审报告
  4. -- 生成时间: 2026-02-12
  5. -- ============================================================
  6. -- 使用事务确保原子性
  7. BEGIN;
  8. -- ============================================================
  9. -- 0. 扩展(可选)
  10. -- ============================================================
  11. CREATE EXTENSION IF NOT EXISTS "uuid-ossp";
  12. DO $$
  13. BEGIN
  14. IF EXISTS (SELECT 1 FROM pg_available_extensions WHERE name = 'vector') THEN
  15. EXECUTE 'CREATE EXTENSION IF NOT EXISTS vector';
  16. ELSE
  17. RAISE NOTICE 'pgvector extension not installed, skip vector features';
  18. END IF;
  19. END $$;
  20. -- ============================================================
  21. -- 0.x 基础业务表(auth/document/parse/ai/extract)
  22. -- ============================================================
  23. -- 用户与会话
  24. CREATE TABLE IF NOT EXISTS users (
  25. id VARCHAR(36) PRIMARY KEY,
  26. username VARCHAR(50) NOT NULL UNIQUE,
  27. email VARCHAR(100) UNIQUE,
  28. password_hash VARCHAR(255) NOT NULL,
  29. display_name VARCHAR(100),
  30. avatar_url VARCHAR(500),
  31. role VARCHAR(20) DEFAULT 'user',
  32. preferences JSONB DEFAULT '{}',
  33. is_active BOOLEAN DEFAULT TRUE,
  34. last_login_at TIMESTAMP,
  35. create_by VARCHAR(36),
  36. create_by_name VARCHAR(100),
  37. create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  38. update_by VARCHAR(36),
  39. update_by_name VARCHAR(100),
  40. update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  41. );
  42. CREATE INDEX IF NOT EXISTS idx_users_username ON users(username);
  43. CREATE INDEX IF NOT EXISTS idx_users_email ON users(email);
  44. CREATE TABLE IF NOT EXISTS sessions (
  45. id VARCHAR(36) PRIMARY KEY,
  46. user_id VARCHAR(36) NOT NULL REFERENCES users(id) ON DELETE CASCADE,
  47. token_hash VARCHAR(255) NOT NULL,
  48. refresh_token_hash VARCHAR(255),
  49. expires_at TIMESTAMP,
  50. ip_address VARCHAR(100),
  51. user_agent TEXT,
  52. last_used_at TIMESTAMP,
  53. create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  54. );
  55. CREATE INDEX IF NOT EXISTS idx_sessions_user ON sessions(user_id);
  56. -- 文档与解析
  57. CREATE TABLE IF NOT EXISTS documents (
  58. id VARCHAR(36) PRIMARY KEY,
  59. user_id VARCHAR(36) NOT NULL REFERENCES users(id) ON DELETE CASCADE,
  60. name VARCHAR(255) NOT NULL,
  61. file_name VARCHAR(500) NOT NULL,
  62. file_path VARCHAR(500) NOT NULL,
  63. file_size BIGINT,
  64. file_type VARCHAR(20) NOT NULL,
  65. status VARCHAR(20) DEFAULT 'uploaded',
  66. parsed_text TEXT,
  67. page_count INT,
  68. word_count INT,
  69. entity_count INT DEFAULT 0,
  70. relation_count INT DEFAULT 0,
  71. rule_count INT DEFAULT 0,
  72. metadata JSONB DEFAULT '{}',
  73. del_flag BOOLEAN DEFAULT FALSE,
  74. create_by VARCHAR(36),
  75. create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  76. update_by VARCHAR(36),
  77. update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  78. );
  79. CREATE INDEX IF NOT EXISTS idx_documents_user ON documents(user_id);
  80. CREATE INDEX IF NOT EXISTS idx_documents_type ON documents(file_type);
  81. CREATE INDEX IF NOT EXISTS idx_documents_status ON documents(status);
  82. CREATE TABLE IF NOT EXISTS document_sections (
  83. id VARCHAR(36) PRIMARY KEY,
  84. document_id VARCHAR(36) NOT NULL REFERENCES documents(id) ON DELETE CASCADE,
  85. parent_id VARCHAR(36) REFERENCES document_sections(id) ON DELETE CASCADE,
  86. section_index INT NOT NULL,
  87. level INT NOT NULL DEFAULT 1,
  88. title VARCHAR(500),
  89. content TEXT,
  90. start_page INT,
  91. end_page INT,
  92. start_char INT,
  93. end_char INT,
  94. section_type VARCHAR(32) DEFAULT 'heading',
  95. table_data JSONB,
  96. image_path VARCHAR(500),
  97. image_caption VARCHAR(500),
  98. metadata JSONB DEFAULT '{}',
  99. sort_order INT DEFAULT 0,
  100. create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  101. );
  102. CREATE INDEX IF NOT EXISTS idx_doc_sections_document ON document_sections(document_id);
  103. CREATE INDEX IF NOT EXISTS idx_doc_sections_parent ON document_sections(parent_id);
  104. CREATE INDEX IF NOT EXISTS idx_doc_sections_level ON document_sections(level);
  105. CREATE INDEX IF NOT EXISTS idx_doc_sections_type ON document_sections(section_type);
  106. CREATE TABLE IF NOT EXISTS document_chunks (
  107. id VARCHAR(36) PRIMARY KEY,
  108. document_id VARCHAR(36) NOT NULL REFERENCES documents(id) ON DELETE CASCADE,
  109. section_id VARCHAR(36) REFERENCES document_sections(id) ON DELETE SET NULL,
  110. chunk_index INT NOT NULL,
  111. content TEXT NOT NULL,
  112. start_char INT,
  113. end_char INT,
  114. page_number INT,
  115. token_count INT,
  116. metadata JSONB DEFAULT '{}',
  117. create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  118. );
  119. CREATE INDEX IF NOT EXISTS idx_doc_chunks_document ON document_chunks(document_id);
  120. CREATE INDEX IF NOT EXISTS idx_doc_chunks_section ON document_chunks(section_id);
  121. CREATE TABLE IF NOT EXISTS parse_tasks (
  122. id VARCHAR(36) PRIMARY KEY,
  123. document_id VARCHAR(36) NOT NULL REFERENCES documents(id) ON DELETE CASCADE,
  124. status VARCHAR(20) DEFAULT 'pending',
  125. progress INT DEFAULT 0,
  126. current_step VARCHAR(32),
  127. error_message TEXT,
  128. options JSONB DEFAULT '{}',
  129. started_at TIMESTAMP,
  130. completed_at TIMESTAMP,
  131. parse_status VARCHAR(20) DEFAULT 'pending',
  132. parse_progress INT DEFAULT 0,
  133. rag_status VARCHAR(20) DEFAULT 'pending',
  134. rag_progress INT DEFAULT 0,
  135. structured_status VARCHAR(20) DEFAULT 'pending',
  136. structured_progress INT DEFAULT 0,
  137. structured_element_count INT,
  138. structured_image_count INT,
  139. structured_table_count INT,
  140. ner_status VARCHAR(20) DEFAULT 'pending',
  141. ner_progress INT DEFAULT 0,
  142. ner_task_id VARCHAR(100),
  143. ner_entity_count INT,
  144. ner_relation_count INT,
  145. ner_message TEXT,
  146. graph_status VARCHAR(20) DEFAULT 'pending',
  147. graph_progress INT DEFAULT 0,
  148. create_by VARCHAR(36),
  149. create_by_name VARCHAR(100),
  150. create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  151. update_by VARCHAR(36),
  152. update_by_name VARCHAR(100),
  153. update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  154. );
  155. CREATE INDEX IF NOT EXISTS idx_parse_tasks_document ON parse_tasks(document_id);
  156. CREATE TABLE IF NOT EXISTS document_elements (
  157. id VARCHAR(36) PRIMARY KEY,
  158. document_id VARCHAR(36) NOT NULL REFERENCES documents(id) ON DELETE CASCADE,
  159. element_index INT,
  160. element_type VARCHAR(50),
  161. content TEXT,
  162. style JSONB DEFAULT '{}',
  163. runs JSONB DEFAULT '[]',
  164. image_url VARCHAR(500),
  165. image_path VARCHAR(500),
  166. image_alt VARCHAR(500),
  167. image_width INT,
  168. image_height INT,
  169. image_format VARCHAR(20),
  170. table_index INT,
  171. table_data JSONB,
  172. table_row_count INT,
  173. table_col_count INT,
  174. table_text TEXT,
  175. create_by VARCHAR(36),
  176. create_by_name VARCHAR(100),
  177. create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  178. update_by VARCHAR(36),
  179. update_by_name VARCHAR(100),
  180. update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  181. );
  182. CREATE INDEX IF NOT EXISTS idx_document_elements_document ON document_elements(document_id);
  183. CREATE TABLE IF NOT EXISTS document_blocks (
  184. id VARCHAR(36) PRIMARY KEY,
  185. document_id VARCHAR(36) NOT NULL REFERENCES documents(id) ON DELETE CASCADE,
  186. parent_id VARCHAR(36),
  187. children JSONB DEFAULT '[]',
  188. block_index INT,
  189. block_type VARCHAR(50),
  190. text_elements JSONB DEFAULT '[]',
  191. table_data JSONB,
  192. image_path VARCHAR(500),
  193. image_url VARCHAR(500),
  194. metadata JSONB DEFAULT '{}',
  195. create_by VARCHAR(36),
  196. create_by_name VARCHAR(100),
  197. create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  198. update_by VARCHAR(36),
  199. update_by_name VARCHAR(100),
  200. update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  201. );
  202. CREATE INDEX IF NOT EXISTS idx_document_blocks_document ON document_blocks(document_id);
  203. -- AI 相关
  204. CREATE TABLE IF NOT EXISTS elements (
  205. id VARCHAR(36) PRIMARY KEY,
  206. document_id VARCHAR(36) REFERENCES documents(id) ON DELETE CASCADE,
  207. user_id VARCHAR(36) REFERENCES users(id) ON DELETE SET NULL,
  208. type VARCHAR(50),
  209. label VARCHAR(200),
  210. value TEXT,
  211. position JSONB DEFAULT '{}',
  212. confidence DECIMAL(10,4),
  213. extraction_method VARCHAR(50),
  214. graph_node_id VARCHAR(36),
  215. metadata JSONB DEFAULT '{}',
  216. create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  217. update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  218. );
  219. CREATE INDEX IF NOT EXISTS idx_elements_document ON elements(document_id);
  220. CREATE TABLE IF NOT EXISTS annotations (
  221. id VARCHAR(36) PRIMARY KEY,
  222. document_id VARCHAR(36) REFERENCES documents(id) ON DELETE CASCADE,
  223. user_id VARCHAR(36) REFERENCES users(id) ON DELETE SET NULL,
  224. text TEXT,
  225. position JSONB DEFAULT '{}',
  226. type VARCHAR(50),
  227. suggestion TEXT,
  228. ai_generated BOOLEAN DEFAULT FALSE,
  229. confidence DECIMAL(10,4),
  230. status VARCHAR(20) DEFAULT 'pending',
  231. create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  232. update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  233. );
  234. CREATE INDEX IF NOT EXISTS idx_annotations_document ON annotations(document_id);
  235. CREATE TABLE IF NOT EXISTS embeddings (
  236. id VARCHAR(36) PRIMARY KEY,
  237. chunk_id VARCHAR(36) NOT NULL REFERENCES document_chunks(id) ON DELETE CASCADE,
  238. embedding vector(1536),
  239. model_name VARCHAR(100) DEFAULT 'text-embedding-ada-002',
  240. model_version VARCHAR(50),
  241. create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  242. );
  243. CREATE INDEX IF NOT EXISTS idx_embeddings_chunk ON embeddings(chunk_id);
  244. CREATE INDEX IF NOT EXISTS idx_embeddings_vector ON embeddings USING ivfflat (embedding vector_cosine_ops) WITH (lists = 100);
  245. -- 提取与模板
  246. CREATE TABLE IF NOT EXISTS extract_projects (
  247. id VARCHAR(36) PRIMARY KEY,
  248. user_id VARCHAR(36) NOT NULL REFERENCES users(id) ON DELETE CASCADE,
  249. name VARCHAR(200) NOT NULL,
  250. description TEXT,
  251. status VARCHAR(50) DEFAULT 'draft',
  252. config JSONB DEFAULT '{}',
  253. create_by VARCHAR(36),
  254. create_by_name VARCHAR(100),
  255. create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  256. update_by VARCHAR(36),
  257. update_by_name VARCHAR(100),
  258. update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  259. );
  260. CREATE INDEX IF NOT EXISTS idx_extract_projects_user ON extract_projects(user_id);
  261. CREATE TABLE IF NOT EXISTS rules (
  262. id VARCHAR(36) PRIMARY KEY,
  263. document_id VARCHAR(36) REFERENCES documents(id) ON DELETE SET NULL,
  264. user_id VARCHAR(36) NOT NULL REFERENCES users(id) ON DELETE CASCADE,
  265. name VARCHAR(200) NOT NULL,
  266. description TEXT,
  267. category VARCHAR(50),
  268. rule_type VARCHAR(32) NOT NULL,
  269. source VARCHAR(32) DEFAULT 'auto',
  270. priority INT DEFAULT 0,
  271. status VARCHAR(20) DEFAULT 'draft',
  272. embedding vector(1536),
  273. is_global BOOLEAN DEFAULT FALSE,
  274. del_flag BOOLEAN DEFAULT FALSE,
  275. create_by VARCHAR(36),
  276. create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  277. update_by VARCHAR(36),
  278. update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  279. );
  280. CREATE INDEX IF NOT EXISTS idx_rules_document ON rules(document_id);
  281. CREATE INDEX IF NOT EXISTS idx_rules_user ON rules(user_id);
  282. CREATE TABLE IF NOT EXISTS templates (
  283. id VARCHAR(36) PRIMARY KEY,
  284. user_id VARCHAR(36) NOT NULL,
  285. name VARCHAR(200),
  286. description TEXT,
  287. base_document_id VARCHAR(36),
  288. status VARCHAR(20) DEFAULT 'draft',
  289. config JSONB DEFAULT '{}',
  290. is_public BOOLEAN DEFAULT FALSE,
  291. use_count INT DEFAULT 0,
  292. rating DOUBLE PRECISION,
  293. create_by VARCHAR(36),
  294. create_by_name VARCHAR(100),
  295. create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  296. update_by VARCHAR(36),
  297. update_by_name VARCHAR(100),
  298. update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  299. );
  300. CREATE INDEX IF NOT EXISTS idx_templates_user ON templates(user_id);
  301. CREATE TABLE IF NOT EXISTS variables (
  302. id VARCHAR(36) PRIMARY KEY,
  303. template_id VARCHAR(36) NOT NULL REFERENCES templates(id) ON DELETE CASCADE,
  304. name VARCHAR(100) NOT NULL,
  305. display_name VARCHAR(200),
  306. variable_group VARCHAR(100),
  307. category VARCHAR(50),
  308. location JSONB,
  309. example_value TEXT,
  310. value_type VARCHAR(20),
  311. source_file_alias VARCHAR(100),
  312. source_type VARCHAR(30),
  313. source_config JSONB DEFAULT '{}',
  314. extract_type VARCHAR(30),
  315. extract_config JSONB DEFAULT '{}',
  316. display_order INT DEFAULT 0,
  317. create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  318. update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  319. );
  320. CREATE INDEX IF NOT EXISTS idx_variables_template ON variables(template_id);
  321. CREATE TABLE IF NOT EXISTS source_files (
  322. id VARCHAR(36) PRIMARY KEY,
  323. template_id VARCHAR(36) NOT NULL REFERENCES templates(id) ON DELETE CASCADE,
  324. alias VARCHAR(100) NOT NULL,
  325. description TEXT,
  326. file_types JSONB DEFAULT '[]',
  327. required BOOLEAN DEFAULT TRUE,
  328. example_document_id VARCHAR(36),
  329. display_order INT DEFAULT 0,
  330. create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  331. );
  332. CREATE INDEX IF NOT EXISTS idx_source_files_template ON source_files(template_id);
  333. -- 报告/附件
  334. CREATE TABLE IF NOT EXISTS reports (
  335. id VARCHAR(36) PRIMARY KEY,
  336. user_id VARCHAR(36) NOT NULL REFERENCES users(id) ON DELETE CASCADE,
  337. project_id VARCHAR(36),
  338. title VARCHAR(500) NOT NULL,
  339. report_type VARCHAR(100),
  340. status VARCHAR(20) NOT NULL DEFAULT 'draft',
  341. content_template TEXT,
  342. content_rendered TEXT,
  343. auto_saved_at TIMESTAMP,
  344. report_score DECIMAL(10,2),
  345. report_level VARCHAR(50),
  346. report_metrics JSONB DEFAULT '{}',
  347. generation_id VARCHAR(36),
  348. source_document_id VARCHAR(36),
  349. archived_at TIMESTAMP,
  350. published_at TIMESTAMP,
  351. del_flag BOOLEAN DEFAULT FALSE,
  352. create_by VARCHAR(36),
  353. create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  354. update_by VARCHAR(36),
  355. update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  356. );
  357. CREATE INDEX IF NOT EXISTS idx_reports_user ON reports(user_id);
  358. CREATE INDEX IF NOT EXISTS idx_reports_status ON reports(status);
  359. CREATE TABLE IF NOT EXISTS report_attachments (
  360. id VARCHAR(36) PRIMARY KEY,
  361. report_id VARCHAR(36) NOT NULL REFERENCES reports(id) ON DELETE CASCADE,
  362. display_name VARCHAR(255),
  363. file_name VARCHAR(500) NOT NULL,
  364. file_path VARCHAR(500) NOT NULL,
  365. file_type VARCHAR(50),
  366. file_size BIGINT,
  367. sort_order INT DEFAULT 0,
  368. saved_to_knowledge_base BOOLEAN DEFAULT FALSE,
  369. knowledge_base_item_id VARCHAR(36),
  370. uploaded_by VARCHAR(36) REFERENCES users(id) ON DELETE SET NULL,
  371. create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  372. );
  373. CREATE INDEX IF NOT EXISTS idx_report_attachments_report ON report_attachments(report_id);
  374. -- ============================================================
  375. -- 1. 建表 (DDL)
  376. -- ============================================================
  377. -- 1.1 节点类型定义表
  378. CREATE TABLE IF NOT EXISTS node_types (
  379. id SERIAL PRIMARY KEY,
  380. type_code VARCHAR(50) NOT NULL UNIQUE,
  381. type_name VARCHAR(100) NOT NULL,
  382. description TEXT,
  383. icon VARCHAR(100),
  384. color VARCHAR(20),
  385. created_at TIMESTAMP DEFAULT NOW()
  386. );
  387. -- 1.2 关系类型定义表
  388. CREATE TABLE IF NOT EXISTS edge_types (
  389. id SERIAL PRIMARY KEY,
  390. type_code VARCHAR(50) NOT NULL UNIQUE,
  391. type_name VARCHAR(100) NOT NULL,
  392. from_node_type VARCHAR(50),
  393. to_node_type VARCHAR(50),
  394. description TEXT,
  395. created_at TIMESTAMP DEFAULT NOW()
  396. );
  397. -- 1.3 节点表(核心)
  398. CREATE TABLE IF NOT EXISTS nodes (
  399. id BIGSERIAL PRIMARY KEY,
  400. node_type VARCHAR(50) NOT NULL,
  401. node_key VARCHAR(200),
  402. name VARCHAR(500) NOT NULL,
  403. status VARCHAR(50) DEFAULT 'active',
  404. created_by BIGINT,
  405. created_at TIMESTAMP DEFAULT NOW(),
  406. updated_at TIMESTAMP DEFAULT NOW()
  407. );
  408. -- 1.4 关系表(核心)
  409. CREATE TABLE IF NOT EXISTS edges (
  410. id BIGSERIAL PRIMARY KEY,
  411. edge_type VARCHAR(50) NOT NULL,
  412. from_node_id BIGINT NOT NULL REFERENCES nodes(id),
  413. to_node_id BIGINT NOT NULL REFERENCES nodes(id),
  414. sort_order INT DEFAULT 0,
  415. created_at TIMESTAMP DEFAULT NOW()
  416. );
  417. -- 1.5 节点属性表
  418. CREATE TABLE IF NOT EXISTS node_properties (
  419. id BIGSERIAL PRIMARY KEY,
  420. node_id BIGINT NOT NULL REFERENCES nodes(id),
  421. prop_key VARCHAR(100) NOT NULL,
  422. prop_value TEXT,
  423. prop_json JSONB,
  424. prop_number DECIMAL(20,4),
  425. prop_date TIMESTAMP,
  426. created_at TIMESTAMP DEFAULT NOW(),
  427. updated_at TIMESTAMP DEFAULT NOW()
  428. );
  429. -- 1.6 关系属性表
  430. CREATE TABLE IF NOT EXISTS edge_properties (
  431. id BIGSERIAL PRIMARY KEY,
  432. edge_id BIGINT NOT NULL REFERENCES edges(id),
  433. prop_key VARCHAR(100) NOT NULL,
  434. prop_value TEXT,
  435. prop_json JSONB,
  436. created_at TIMESTAMP DEFAULT NOW()
  437. );
  438. -- 1.7 属性定义表
  439. CREATE TABLE IF NOT EXISTS property_definitions (
  440. id SERIAL PRIMARY KEY,
  441. owner_type VARCHAR(20) NOT NULL,
  442. target_type VARCHAR(50) NOT NULL,
  443. prop_key VARCHAR(100) NOT NULL,
  444. prop_name VARCHAR(200) NOT NULL,
  445. data_type VARCHAR(50) NOT NULL,
  446. required BOOLEAN DEFAULT false,
  447. default_value TEXT,
  448. description TEXT,
  449. created_at TIMESTAMP DEFAULT NOW()
  450. );
  451. -- ============================================================
  452. -- 1.x 兼容字段与触发器(兼容后端实体字段命名)
  453. -- ============================================================
  454. -- node_properties: 兼容 graph-service 使用 prop_text 字段
  455. ALTER TABLE node_properties ADD COLUMN IF NOT EXISTS prop_text TEXT;
  456. CREATE OR REPLACE FUNCTION sync_node_properties_text() RETURNS trigger AS $$
  457. BEGIN
  458. IF NEW.prop_text IS NULL AND NEW.prop_value IS NOT NULL THEN
  459. NEW.prop_text := NEW.prop_value;
  460. ELSIF NEW.prop_value IS NULL AND NEW.prop_text IS NOT NULL THEN
  461. NEW.prop_value := NEW.prop_text;
  462. END IF;
  463. RETURN NEW;
  464. END;
  465. $$ LANGUAGE plpgsql;
  466. DROP TRIGGER IF EXISTS trg_sync_node_properties_text ON node_properties;
  467. CREATE TRIGGER trg_sync_node_properties_text
  468. BEFORE INSERT OR UPDATE ON node_properties
  469. FOR EACH ROW EXECUTE FUNCTION sync_node_properties_text();
  470. -- edge_properties: 兼容 graph-service 使用 prop_text 字段
  471. ALTER TABLE edge_properties ADD COLUMN IF NOT EXISTS prop_text TEXT;
  472. CREATE OR REPLACE FUNCTION sync_edge_properties_text() RETURNS trigger AS $$
  473. BEGIN
  474. IF NEW.prop_text IS NULL AND NEW.prop_value IS NOT NULL THEN
  475. NEW.prop_text := NEW.prop_value;
  476. ELSIF NEW.prop_value IS NULL AND NEW.prop_text IS NOT NULL THEN
  477. NEW.prop_value := NEW.prop_text;
  478. END IF;
  479. RETURN NEW;
  480. END;
  481. $$ LANGUAGE plpgsql;
  482. DROP TRIGGER IF EXISTS trg_sync_edge_properties_text ON edge_properties;
  483. CREATE TRIGGER trg_sync_edge_properties_text
  484. BEFORE INSERT OR UPDATE ON edge_properties
  485. FOR EACH ROW EXECUTE FUNCTION sync_edge_properties_text();
  486. -- property_definitions: 兼容 graph-service 使用 type_code/is_required 字段
  487. ALTER TABLE property_definitions ADD COLUMN IF NOT EXISTS type_code VARCHAR(50);
  488. ALTER TABLE property_definitions ADD COLUMN IF NOT EXISTS is_required BOOLEAN;
  489. CREATE OR REPLACE FUNCTION sync_property_definitions_fields() RETURNS trigger AS $$
  490. BEGIN
  491. IF NEW.type_code IS NULL AND NEW.target_type IS NOT NULL THEN
  492. NEW.type_code := NEW.target_type;
  493. ELSIF NEW.target_type IS NULL AND NEW.type_code IS NOT NULL THEN
  494. NEW.target_type := NEW.type_code;
  495. END IF;
  496. IF NEW.is_required IS NULL AND NEW.required IS NOT NULL THEN
  497. NEW.is_required := NEW.required;
  498. ELSIF NEW.required IS NULL AND NEW.is_required IS NOT NULL THEN
  499. NEW.required := NEW.is_required;
  500. END IF;
  501. RETURN NEW;
  502. END;
  503. $$ LANGUAGE plpgsql;
  504. DROP TRIGGER IF EXISTS trg_sync_property_definitions_fields ON property_definitions;
  505. CREATE TRIGGER trg_sync_property_definitions_fields
  506. BEFORE INSERT OR UPDATE ON property_definitions
  507. FOR EACH ROW EXECUTE FUNCTION sync_property_definitions_fields();
  508. -- ============================================================
  509. -- 1.8 前端业务支撑表
  510. -- ============================================================
  511. -- 1.8.1 用户扩展表(扩展nodes中的USER节点)
  512. CREATE TABLE IF NOT EXISTS sys_users (
  513. id BIGSERIAL PRIMARY KEY,
  514. node_id BIGINT REFERENCES nodes(id),
  515. username VARCHAR(100) NOT NULL UNIQUE,
  516. password_hash VARCHAR(255) NOT NULL,
  517. salt VARCHAR(50),
  518. email VARCHAR(200),
  519. phone VARCHAR(20),
  520. avatar VARCHAR(500),
  521. real_name VARCHAR(100),
  522. department VARCHAR(200),
  523. position VARCHAR(100),
  524. status VARCHAR(20) DEFAULT 'active',
  525. last_login_at TIMESTAMP,
  526. last_login_ip VARCHAR(50),
  527. login_count INT DEFAULT 0,
  528. created_at TIMESTAMP DEFAULT NOW(),
  529. updated_at TIMESTAMP DEFAULT NOW()
  530. );
  531. -- 1.8.2 会话表
  532. CREATE TABLE IF NOT EXISTS sys_sessions (
  533. id BIGSERIAL PRIMARY KEY,
  534. user_id BIGINT NOT NULL REFERENCES sys_users(id),
  535. session_token VARCHAR(255) NOT NULL UNIQUE,
  536. refresh_token VARCHAR(255),
  537. device_type VARCHAR(50),
  538. device_info TEXT,
  539. ip_address VARCHAR(50),
  540. user_agent TEXT,
  541. expires_at TIMESTAMP NOT NULL,
  542. created_at TIMESTAMP DEFAULT NOW(),
  543. updated_at TIMESTAMP DEFAULT NOW()
  544. );
  545. -- 1.8.3 登录日志表
  546. CREATE TABLE IF NOT EXISTS sys_login_logs (
  547. id BIGSERIAL PRIMARY KEY,
  548. user_id BIGINT REFERENCES sys_users(id),
  549. username VARCHAR(100),
  550. login_type VARCHAR(20),
  551. ip_address VARCHAR(50),
  552. user_agent TEXT,
  553. device_type VARCHAR(50),
  554. location VARCHAR(200),
  555. status VARCHAR(20) NOT NULL,
  556. message TEXT,
  557. created_at TIMESTAMP DEFAULT NOW()
  558. );
  559. -- 1.8.4 角色表
  560. CREATE TABLE IF NOT EXISTS sys_roles (
  561. id SERIAL PRIMARY KEY,
  562. role_code VARCHAR(50) NOT NULL UNIQUE,
  563. role_name VARCHAR(100) NOT NULL,
  564. description TEXT,
  565. sort_order INT DEFAULT 0,
  566. status VARCHAR(20) DEFAULT 'active',
  567. created_by BIGINT,
  568. created_at TIMESTAMP DEFAULT NOW(),
  569. updated_at TIMESTAMP DEFAULT NOW()
  570. );
  571. -- 1.8.5 权限表
  572. CREATE TABLE IF NOT EXISTS sys_permissions (
  573. id SERIAL PRIMARY KEY,
  574. perm_code VARCHAR(100) NOT NULL UNIQUE,
  575. perm_name VARCHAR(200) NOT NULL,
  576. perm_type VARCHAR(20) NOT NULL,
  577. parent_id INT REFERENCES sys_permissions(id),
  578. path VARCHAR(500),
  579. icon VARCHAR(100),
  580. component VARCHAR(200),
  581. sort_order INT DEFAULT 0,
  582. status VARCHAR(20) DEFAULT 'active',
  583. created_at TIMESTAMP DEFAULT NOW()
  584. );
  585. -- 1.8.6 用户角色关联表
  586. CREATE TABLE IF NOT EXISTS sys_user_roles (
  587. id SERIAL PRIMARY KEY,
  588. user_id BIGINT NOT NULL REFERENCES sys_users(id),
  589. role_id INT NOT NULL REFERENCES sys_roles(id),
  590. created_at TIMESTAMP DEFAULT NOW(),
  591. UNIQUE(user_id, role_id)
  592. );
  593. -- 1.8.7 角色权限关联表
  594. CREATE TABLE IF NOT EXISTS sys_role_permissions (
  595. id SERIAL PRIMARY KEY,
  596. role_id INT NOT NULL REFERENCES sys_roles(id),
  597. permission_id INT NOT NULL REFERENCES sys_permissions(id),
  598. created_at TIMESTAMP DEFAULT NOW(),
  599. UNIQUE(role_id, permission_id)
  600. );
  601. -- 1.8.8 系统配置表
  602. CREATE TABLE IF NOT EXISTS sys_configs (
  603. id SERIAL PRIMARY KEY,
  604. config_key VARCHAR(100) NOT NULL UNIQUE,
  605. config_value TEXT,
  606. config_json JSONB,
  607. config_type VARCHAR(50),
  608. description TEXT,
  609. is_public BOOLEAN DEFAULT false,
  610. created_at TIMESTAMP DEFAULT NOW(),
  611. updated_at TIMESTAMP DEFAULT NOW()
  612. );
  613. -- 1.8.9 数据字典类型表
  614. CREATE TABLE IF NOT EXISTS sys_dict_types (
  615. id SERIAL PRIMARY KEY,
  616. dict_code VARCHAR(100) NOT NULL UNIQUE,
  617. dict_name VARCHAR(200) NOT NULL,
  618. description TEXT,
  619. status VARCHAR(20) DEFAULT 'active',
  620. created_at TIMESTAMP DEFAULT NOW()
  621. );
  622. -- 1.8.10 数据字典项表
  623. CREATE TABLE IF NOT EXISTS sys_dict_items (
  624. id SERIAL PRIMARY KEY,
  625. dict_type_id INT NOT NULL REFERENCES sys_dict_types(id),
  626. item_code VARCHAR(100) NOT NULL,
  627. item_name VARCHAR(200) NOT NULL,
  628. item_value TEXT,
  629. sort_order INT DEFAULT 0,
  630. status VARCHAR(20) DEFAULT 'active',
  631. extra JSONB,
  632. created_at TIMESTAMP DEFAULT NOW(),
  633. UNIQUE(dict_type_id, item_code)
  634. );
  635. -- 1.8.11 操作日志表
  636. CREATE TABLE IF NOT EXISTS sys_operation_logs (
  637. id BIGSERIAL PRIMARY KEY,
  638. user_id BIGINT,
  639. username VARCHAR(100),
  640. module VARCHAR(100),
  641. action VARCHAR(100),
  642. method VARCHAR(10),
  643. url VARCHAR(500),
  644. params TEXT,
  645. result TEXT,
  646. ip_address VARCHAR(50),
  647. user_agent TEXT,
  648. duration_ms INT,
  649. status VARCHAR(20),
  650. error_msg TEXT,
  651. created_at TIMESTAMP DEFAULT NOW()
  652. );
  653. -- 1.8.12 文件存储表
  654. CREATE TABLE IF NOT EXISTS sys_files (
  655. id BIGSERIAL PRIMARY KEY,
  656. file_key VARCHAR(100) NOT NULL UNIQUE,
  657. original_name VARCHAR(500) NOT NULL,
  658. storage_name VARCHAR(200) NOT NULL,
  659. storage_path VARCHAR(500) NOT NULL,
  660. file_type VARCHAR(100),
  661. file_size BIGINT,
  662. md5_hash VARCHAR(32),
  663. storage_type VARCHAR(20) DEFAULT 'local',
  664. bucket VARCHAR(100),
  665. url VARCHAR(1000),
  666. thumbnail_url VARCHAR(1000),
  667. uploaded_by BIGINT,
  668. created_at TIMESTAMP DEFAULT NOW()
  669. );
  670. -- 1.8.13 任务队列表(异步任务)
  671. CREATE TABLE IF NOT EXISTS sys_tasks (
  672. id BIGSERIAL PRIMARY KEY,
  673. task_type VARCHAR(50) NOT NULL,
  674. task_key VARCHAR(100),
  675. payload JSONB,
  676. status VARCHAR(20) DEFAULT 'pending',
  677. priority INT DEFAULT 0,
  678. retry_count INT DEFAULT 0,
  679. max_retries INT DEFAULT 3,
  680. result JSONB,
  681. error_msg TEXT,
  682. started_at TIMESTAMP,
  683. finished_at TIMESTAMP,
  684. created_by BIGINT,
  685. created_at TIMESTAMP DEFAULT NOW(),
  686. updated_at TIMESTAMP DEFAULT NOW()
  687. );
  688. -- ============================================================
  689. -- 2. 索引
  690. -- ============================================================
  691. -- nodes
  692. CREATE INDEX IF NOT EXISTS idx_nodes_type ON nodes(node_type);
  693. CREATE INDEX IF NOT EXISTS idx_nodes_type_status ON nodes(node_type, status);
  694. CREATE INDEX IF NOT EXISTS idx_nodes_key ON nodes(node_key);
  695. CREATE UNIQUE INDEX IF NOT EXISTS idx_nodes_type_key ON nodes(node_type, node_key) WHERE node_key IS NOT NULL;
  696. CREATE INDEX IF NOT EXISTS idx_nodes_created_by ON nodes(created_by);
  697. CREATE INDEX IF NOT EXISTS idx_nodes_created_at ON nodes(created_at DESC);
  698. -- edges
  699. CREATE INDEX IF NOT EXISTS idx_edges_type ON edges(edge_type);
  700. CREATE INDEX IF NOT EXISTS idx_edges_from ON edges(from_node_id);
  701. CREATE INDEX IF NOT EXISTS idx_edges_to ON edges(to_node_id);
  702. CREATE INDEX IF NOT EXISTS idx_edges_type_from ON edges(edge_type, from_node_id);
  703. CREATE INDEX IF NOT EXISTS idx_edges_type_to ON edges(edge_type, to_node_id);
  704. CREATE UNIQUE INDEX IF NOT EXISTS idx_edges_unique ON edges(edge_type, from_node_id, to_node_id);
  705. -- node_properties
  706. CREATE INDEX IF NOT EXISTS idx_node_props_node ON node_properties(node_id);
  707. CREATE UNIQUE INDEX IF NOT EXISTS idx_node_props_unique ON node_properties(node_id, prop_key);
  708. CREATE INDEX IF NOT EXISTS idx_node_props_key ON node_properties(prop_key);
  709. -- edge_properties
  710. CREATE INDEX IF NOT EXISTS idx_edge_props_edge ON edge_properties(edge_id);
  711. CREATE UNIQUE INDEX IF NOT EXISTS idx_edge_props_unique ON edge_properties(edge_id, prop_key);
  712. -- sys_users
  713. CREATE INDEX IF NOT EXISTS idx_sys_users_node ON sys_users(node_id);
  714. CREATE INDEX IF NOT EXISTS idx_sys_users_status ON sys_users(status);
  715. CREATE INDEX IF NOT EXISTS idx_sys_users_email ON sys_users(email);
  716. CREATE INDEX IF NOT EXISTS idx_sys_users_phone ON sys_users(phone);
  717. -- sys_sessions
  718. CREATE INDEX IF NOT EXISTS idx_sys_sessions_user ON sys_sessions(user_id);
  719. CREATE INDEX IF NOT EXISTS idx_sys_sessions_expires ON sys_sessions(expires_at);
  720. CREATE INDEX IF NOT EXISTS idx_sys_sessions_refresh ON sys_sessions(refresh_token);
  721. -- sys_login_logs
  722. CREATE INDEX IF NOT EXISTS idx_sys_login_logs_user ON sys_login_logs(user_id);
  723. CREATE INDEX IF NOT EXISTS idx_sys_login_logs_time ON sys_login_logs(created_at DESC);
  724. -- sys_roles
  725. CREATE INDEX IF NOT EXISTS idx_sys_roles_status ON sys_roles(status);
  726. -- sys_permissions
  727. CREATE INDEX IF NOT EXISTS idx_sys_perms_parent ON sys_permissions(parent_id);
  728. CREATE INDEX IF NOT EXISTS idx_sys_perms_type ON sys_permissions(perm_type);
  729. -- sys_operation_logs
  730. CREATE INDEX IF NOT EXISTS idx_sys_op_logs_user ON sys_operation_logs(user_id);
  731. CREATE INDEX IF NOT EXISTS idx_sys_op_logs_time ON sys_operation_logs(created_at DESC);
  732. CREATE INDEX IF NOT EXISTS idx_sys_op_logs_module ON sys_operation_logs(module);
  733. -- sys_files
  734. CREATE INDEX IF NOT EXISTS idx_sys_files_uploaded ON sys_files(uploaded_by);
  735. CREATE INDEX IF NOT EXISTS idx_sys_files_type ON sys_files(file_type);
  736. CREATE INDEX IF NOT EXISTS idx_sys_files_time ON sys_files(created_at DESC);
  737. -- sys_tasks
  738. CREATE INDEX IF NOT EXISTS idx_sys_tasks_status ON sys_tasks(status);
  739. CREATE INDEX IF NOT EXISTS idx_sys_tasks_type ON sys_tasks(task_type);
  740. CREATE INDEX IF NOT EXISTS idx_sys_tasks_priority ON sys_tasks(priority DESC, created_at);
  741. -- ============================================================
  742. -- 3. 视图 (Views)
  743. -- ============================================================
  744. -- 3.1 原始文件视图
  745. CREATE OR REPLACE VIEW v_source_files AS
  746. SELECT
  747. n.id,
  748. n.name AS file_name,
  749. n.node_key AS file_key,
  750. n.status,
  751. n.created_at,
  752. n.updated_at,
  753. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'original_name') AS original_name,
  754. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'file_path') AS file_path,
  755. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'file_type') AS file_type,
  756. (SELECT prop_number FROM node_properties WHERE node_id = n.id AND prop_key = 'file_size')::bigint AS file_size,
  757. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'content_html') AS content_html,
  758. (SELECT prop_json FROM node_properties WHERE node_id = n.id AND prop_key = 'content_json') AS content_json,
  759. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'parse_status') AS parse_status,
  760. (SELECT prop_date FROM node_properties WHERE node_id = n.id AND prop_key = 'parsed_at') AS parsed_at,
  761. (SELECT n2.id FROM edges e JOIN nodes n2 ON n2.id = e.to_node_id
  762. WHERE e.from_node_id = n.id AND e.edge_type = 'PARSED_TO' LIMIT 1) AS template_id,
  763. n.created_by,
  764. (SELECT n2.name FROM nodes n2 WHERE n2.id = n.created_by) AS created_by_name
  765. FROM nodes n
  766. WHERE n.node_type = 'SOURCE_FILE';
  767. -- 3.2 模板视图
  768. CREATE OR REPLACE VIEW v_templates AS
  769. SELECT
  770. n.id,
  771. n.name,
  772. n.node_key AS template_code,
  773. n.status,
  774. n.created_at,
  775. n.updated_at,
  776. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'category') AS category,
  777. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'description') AS description,
  778. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'content_html') AS content_html,
  779. (SELECT prop_json FROM node_properties WHERE node_id = n.id AND prop_key = 'content_json') AS content_json,
  780. (SELECT COUNT(*) FROM edges e WHERE e.from_node_id = n.id AND e.edge_type = 'HAS_ELEMENT') AS element_count,
  781. (SELECT n2.name FROM nodes n2 WHERE n2.id = n.created_by) AS created_by_name
  782. FROM nodes n
  783. WHERE n.node_type = 'TEMPLATE';
  784. -- 3.3 报告视图
  785. CREATE OR REPLACE VIEW v_reports AS
  786. SELECT
  787. n.id,
  788. n.name AS title,
  789. n.node_key AS report_code,
  790. n.status,
  791. n.created_at,
  792. n.updated_at,
  793. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'report_type') AS report_type,
  794. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'content_html') AS content_html,
  795. (SELECT n2.id FROM edges e JOIN nodes n2 ON n2.id = e.to_node_id
  796. WHERE e.from_node_id = n.id AND e.edge_type = 'INSTANCE_OF' LIMIT 1) AS template_id,
  797. (SELECT n2.name FROM edges e JOIN nodes n2 ON n2.id = e.to_node_id
  798. WHERE e.from_node_id = n.id AND e.edge_type = 'INSTANCE_OF' LIMIT 1) AS template_name,
  799. (SELECT n2.id FROM edges e JOIN nodes n2 ON n2.id = e.to_node_id
  800. WHERE e.from_node_id = n.id AND e.edge_type = 'BELONGS_TO' AND n2.node_type = 'PROJECT' LIMIT 1) AS project_id,
  801. (SELECT n2.name FROM edges e JOIN nodes n2 ON n2.id = e.to_node_id
  802. WHERE e.from_node_id = n.id AND e.edge_type = 'BELONGS_TO' AND n2.node_type = 'PROJECT' LIMIT 1) AS project_name,
  803. (SELECT n2.id FROM edges e JOIN nodes n2 ON n2.id = e.to_node_id
  804. WHERE e.from_node_id = n.id AND e.edge_type = 'COPIED_FROM' LIMIT 1) AS source_report_id,
  805. (SELECT COUNT(*) FROM edges e WHERE e.from_node_id = n.id AND e.edge_type = 'HAS_ATTACHMENT') AS attachment_count,
  806. n.created_by,
  807. (SELECT n2.name FROM nodes n2 WHERE n2.id = n.created_by) AS created_by_name
  808. FROM nodes n
  809. WHERE n.node_type = 'REPORT';
  810. -- 3.4 模板动态要素视图
  811. CREATE OR REPLACE VIEW v_template_elements AS
  812. SELECT
  813. n.id,
  814. n.name AS element_name,
  815. n.node_key AS element_key,
  816. n.created_at,
  817. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'element_type') AS element_type,
  818. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'namespace') AS namespace,
  819. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'field_name') AS field_name,
  820. (SELECT prop_json FROM node_properties WHERE node_id = n.id AND prop_key = 'table_columns') AS table_columns,
  821. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'required')::boolean AS required,
  822. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'default_value') AS default_value,
  823. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'description') AS description,
  824. (SELECT e.from_node_id FROM edges e WHERE e.to_node_id = n.id AND e.edge_type = 'HAS_ELEMENT' LIMIT 1) AS template_id,
  825. (SELECT e.sort_order FROM edges e WHERE e.to_node_id = n.id AND e.edge_type = 'HAS_ELEMENT' LIMIT 1) AS sort_order
  826. FROM nodes n
  827. WHERE n.node_type = 'ELEMENT';
  828. -- 3.5 报告要素值视图
  829. CREATE OR REPLACE VIEW v_report_element_values AS
  830. SELECT
  831. n.id AS value_id,
  832. n.node_key AS element_key,
  833. n.created_at,
  834. n.updated_at,
  835. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'value_text') AS value_text,
  836. (SELECT prop_json FROM node_properties WHERE node_id = n.id AND prop_key = 'value_json') AS value_json,
  837. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'is_filled')::boolean AS is_filled,
  838. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'fill_source') AS fill_source,
  839. (SELECT e.from_node_id FROM edges e WHERE e.to_node_id = n.id AND e.edge_type = 'HAS_VALUE' LIMIT 1) AS report_id
  840. FROM nodes n
  841. WHERE n.node_type = 'VALUE';
  842. -- 3.6 附件视图
  843. CREATE OR REPLACE VIEW v_attachments AS
  844. SELECT
  845. n.id,
  846. n.name AS display_name,
  847. n.node_key AS file_key,
  848. n.created_at,
  849. n.updated_at,
  850. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'file_name') AS file_name,
  851. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'file_path') AS file_path,
  852. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'file_type') AS file_type,
  853. (SELECT prop_number FROM node_properties WHERE node_id = n.id AND prop_key = 'file_size')::bigint AS file_size,
  854. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'parse_status') AS parse_status,
  855. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'parsed_text') AS parsed_text,
  856. (SELECT prop_date FROM node_properties WHERE node_id = n.id AND prop_key = 'parsed_at') AS parsed_at,
  857. (SELECT COUNT(*) FROM edges e WHERE e.from_node_id = n.id AND e.edge_type = 'HAS_ENTITY') AS entity_count,
  858. (SELECT e.from_node_id FROM edges e WHERE e.to_node_id = n.id AND e.edge_type = 'HAS_ATTACHMENT' LIMIT 1) AS report_id,
  859. (SELECT e.sort_order FROM edges e WHERE e.to_node_id = n.id AND e.edge_type = 'HAS_ATTACHMENT' LIMIT 1) AS sort_order
  860. FROM nodes n
  861. WHERE n.node_type = 'ATTACHMENT';
  862. -- 3.7 实体视图
  863. CREATE OR REPLACE VIEW v_entities AS
  864. SELECT
  865. n.id,
  866. n.name AS entity_text,
  867. n.node_key AS entity_key,
  868. n.created_at,
  869. n.updated_at,
  870. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'entity_type') AS entity_type,
  871. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'business_label') AS business_label,
  872. (SELECT prop_number FROM node_properties WHERE node_id = n.id AND prop_key = 'confidence') AS confidence,
  873. (SELECT prop_number FROM node_properties WHERE node_id = n.id AND prop_key = 'occurrence_count')::int AS occurrence_count,
  874. (SELECT e.from_node_id FROM edges e WHERE e.to_node_id = n.id AND e.edge_type = 'HAS_ENTITY' LIMIT 1) AS attachment_id
  875. FROM nodes n
  876. WHERE n.node_type = 'ENTITY';
  877. -- 3.8 规则视图
  878. CREATE OR REPLACE VIEW v_rules AS
  879. SELECT
  880. n.id,
  881. n.name AS rule_name,
  882. n.node_key AS element_key,
  883. n.status,
  884. n.created_at,
  885. n.updated_at,
  886. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'description') AS description,
  887. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'rule_type') AS rule_type,
  888. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'action_type') AS action_type,
  889. (SELECT prop_json FROM node_properties WHERE node_id = n.id AND prop_key = 'action_config') AS action_config,
  890. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'dsl_content') AS dsl_content,
  891. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'last_output_text') AS last_output_text,
  892. (SELECT prop_json FROM node_properties WHERE node_id = n.id AND prop_key = 'last_output_json') AS last_output_json,
  893. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'last_run_status') AS last_run_status,
  894. (SELECT prop_date FROM node_properties WHERE node_id = n.id AND prop_key = 'last_run_time') AS last_run_time,
  895. (SELECT prop_value FROM node_properties WHERE node_id = n.id AND prop_key = 'last_run_error') AS last_run_error,
  896. (SELECT e.from_node_id FROM edges e WHERE e.to_node_id = n.id AND e.edge_type = 'HAS_RULE' LIMIT 1) AS report_id
  897. FROM nodes n
  898. WHERE n.node_type = 'RULE';
  899. -- 3.9 规则输入视图
  900. CREATE OR REPLACE VIEW v_rule_inputs AS
  901. SELECT
  902. e.id AS input_id,
  903. e.from_node_id AS rule_id,
  904. e.to_node_id AS source_node_id,
  905. e.sort_order,
  906. (SELECT prop_value FROM edge_properties WHERE edge_id = e.id AND prop_key = 'input_key') AS input_key,
  907. (SELECT prop_value FROM edge_properties WHERE edge_id = e.id AND prop_key = 'input_name') AS input_name,
  908. (SELECT prop_value FROM edge_properties WHERE edge_id = e.id AND prop_key = 'input_type') AS input_type,
  909. (SELECT prop_value FROM edge_properties WHERE edge_id = e.id AND prop_key = 'fixed_value') AS fixed_value,
  910. n.node_type AS source_type,
  911. n.name AS source_name
  912. FROM edges e
  913. JOIN nodes n ON n.id = e.to_node_id
  914. WHERE e.edge_type = 'INPUT_FROM';
  915. -- 3.10 报告完整视图(聚合)
  916. CREATE OR REPLACE VIEW v_report_full AS
  917. SELECT
  918. r.*,
  919. (SELECT COUNT(*) FROM v_report_element_values v WHERE v.report_id = r.id AND v.is_filled = true) AS filled_count,
  920. (SELECT COUNT(*) FROM v_template_elements te WHERE te.template_id = r.template_id) AS total_elements,
  921. (SELECT COUNT(*) FROM v_rules ru WHERE ru.report_id = r.id) AS rule_count,
  922. (SELECT COUNT(*) FROM v_rules ru WHERE ru.report_id = r.id AND ru.last_run_status = 'success') AS success_rule_count
  923. FROM v_reports r;
  924. -- ============================================================
  925. -- 4. 初始化数据 (DML)
  926. -- ============================================================
  927. -- 4.1 节点类型
  928. INSERT INTO node_types (type_code, type_name, description) VALUES
  929. ('SOURCE_FILE', '原始文件', '用户上传的原始样本文件'),
  930. ('TEMPLATE', '模板', '报告模板(规则骨架)'),
  931. ('ELEMENT', '要素定义', '动态要素定义(属于模板)'),
  932. ('REPORT', '报告', '报告实例(属于项目)'),
  933. ('VALUE', '要素值', '要素值(属于报告)'),
  934. ('RULE', '规则', '规则实例(属于报告)'),
  935. ('ATTACHMENT', '附件', '附件(属于报告)'),
  936. ('ENTITY', '实体', '识别实体(属于样本文件或附件)'),
  937. ('USER', '用户', '系统用户'),
  938. ('PROJECT', '项目', '项目');
  939. -- 4.2 关系类型
  940. INSERT INTO edge_types (type_code, type_name, from_node_type, to_node_type, description) VALUES
  941. ('PARSED_TO', '解析生成', 'SOURCE_FILE', 'TEMPLATE', '原始文件解析生成模板'),
  942. ('HAS_ELEMENT', '包含要素', 'TEMPLATE', 'ELEMENT', '模板包含要素定义'),
  943. ('INSTANCE_OF', '实例化', 'REPORT', 'TEMPLATE', '报告基于模板'),
  944. ('HAS_VALUE', '有要素值', 'REPORT', 'VALUE', '报告有要素值'),
  945. ('HAS_RULE', '有规则', 'REPORT', 'RULE', '报告有规则'),
  946. ('FOR_ELEMENT', '对应要素', NULL, 'ELEMENT', '规则/值对应的要素'),
  947. ('HAS_ATTACHMENT', '有附件', 'REPORT', 'ATTACHMENT', '报告有附件'),
  948. ('HAS_ENTITY', '有实体', NULL, 'ENTITY', '文件有实体(本文或附件)'),
  949. ('INPUT_FROM', '输入来源', 'RULE', NULL, '规则输入来源'),
  950. ('COPIED_FROM', '复制来源', 'REPORT', 'REPORT', '复制来源'),
  951. ('BELONGS_TO', '归属', 'REPORT', 'PROJECT', '归属关系'),
  952. ('CREATED_BY', '创建者', NULL, 'USER', '创建者');
  953. -- 4.3 属性定义
  954. INSERT INTO property_definitions (owner_type, target_type, prop_key, prop_name, data_type, required, description) VALUES
  955. -- SOURCE_FILE 节点属性
  956. ('node', 'SOURCE_FILE', 'original_name', '原始文件名', 'text', true, '上传时的原始文件名'),
  957. ('node', 'SOURCE_FILE', 'file_path', '存储路径', 'text', true, '服务器存储路径'),
  958. ('node', 'SOURCE_FILE', 'file_type', '文件类型', 'text', true, 'MIME类型'),
  959. ('node', 'SOURCE_FILE', 'file_size', '文件大小', 'number', false, '字节数'),
  960. ('node', 'SOURCE_FILE', 'content_html', 'HTML内容', 'text', false, '解析后的HTML'),
  961. ('node', 'SOURCE_FILE', 'content_json', '结构化内容', 'json', false, '解析后的JSON结构'),
  962. ('node', 'SOURCE_FILE', 'parse_status', '解析状态', 'text', false, 'pending/parsing/completed/failed'),
  963. ('node', 'SOURCE_FILE', 'parsed_at', '解析时间', 'date', false, '解析完成时间'),
  964. -- TEMPLATE 节点属性
  965. ('node', 'TEMPLATE', 'category', '分类', 'text', false, '模板分类'),
  966. ('node', 'TEMPLATE', 'description', '描述', 'text', false, '模板描述'),
  967. ('node', 'TEMPLATE', 'content_html', 'HTML内容', 'text', false, '模板HTML(含占位符)'),
  968. ('node', 'TEMPLATE', 'content_json', '结构化内容', 'json', false, '模板JSON结构'),
  969. -- ELEMENT 节点属性
  970. ('node', 'ELEMENT', 'element_type', '要素类型', 'text', true, 'text/paragraph/table'),
  971. ('node', 'ELEMENT', 'namespace', '命名空间', 'text', false, '如basicInfo/project'),
  972. ('node', 'ELEMENT', 'field_name', '字段名', 'text', false, '如projectCode'),
  973. ('node', 'ELEMENT', 'table_columns', '表格列定义', 'json', false, '表格类型的列定义'),
  974. ('node', 'ELEMENT', 'required', '是否必填', 'text', false, 'true/false'),
  975. ('node', 'ELEMENT', 'default_value', '默认值', 'text', false, '默认填充值'),
  976. ('node', 'ELEMENT', 'description', '描述', 'text', false, '要素描述'),
  977. -- REPORT 节点属性
  978. ('node', 'REPORT', 'report_type', '报告类型', 'text', false, '报告类型标识'),
  979. ('node', 'REPORT', 'content_html', 'HTML内容', 'text', false, '生成的报告HTML'),
  980. -- VALUE 节点属性
  981. ('node', 'VALUE', 'value_text', '文本值', 'text', false, '要素的文本值'),
  982. ('node', 'VALUE', 'value_json', 'JSON值', 'json', false, '要素的JSON值(表格等)'),
  983. ('node', 'VALUE', 'is_filled', '是否已填充', 'text', false, 'true/false'),
  984. ('node', 'VALUE', 'fill_source', '填充来源', 'text', false, 'manual/rule/default'),
  985. -- RULE 节点属性
  986. ('node', 'RULE', 'description', '描述', 'text', false, '规则描述'),
  987. ('node', 'RULE', 'rule_type', '规则类型', 'text', false, 'extract/aggregate/calculate'),
  988. ('node', 'RULE', 'action_type', '动作类型', 'text', false, 'llm/script/lookup'),
  989. ('node', 'RULE', 'action_config', '动作配置', 'json', false, '动作参数配置'),
  990. ('node', 'RULE', 'dsl_content', 'DSL内容', 'text', false, '规则DSL定义'),
  991. ('node', 'RULE', 'last_output_text', '最后输出文本', 'text', false, '最后执行的文本输出'),
  992. ('node', 'RULE', 'last_output_json', '最后输出JSON', 'json', false, '最后执行的JSON输出'),
  993. ('node', 'RULE', 'last_run_status', '最后执行状态', 'text', false, 'pending/running/success/failed'),
  994. ('node', 'RULE', 'last_run_time', '最后执行时间', 'date', false, '最后执行时间'),
  995. ('node', 'RULE', 'last_run_error', '最后执行错误', 'text', false, '错误信息'),
  996. -- ATTACHMENT 节点属性
  997. ('node', 'ATTACHMENT', 'file_name', '文件名', 'text', true, '附件文件名'),
  998. ('node', 'ATTACHMENT', 'file_path', '存储路径', 'text', true, '服务器存储路径'),
  999. ('node', 'ATTACHMENT', 'file_type', '文件类型', 'text', false, 'MIME类型'),
  1000. ('node', 'ATTACHMENT', 'file_size', '文件大小', 'number', false, '字节数'),
  1001. ('node', 'ATTACHMENT', 'parse_status', '解析状态', 'text', false, 'pending/parsing/completed/failed'),
  1002. ('node', 'ATTACHMENT', 'parsed_text', '解析文本', 'text', false, '解析后的纯文本'),
  1003. ('node', 'ATTACHMENT', 'parsed_at', '解析时间', 'date', false, '解析完成时间'),
  1004. -- ENTITY 节点属性
  1005. ('node', 'ENTITY', 'entity_type', '实体类型', 'text', true, 'PERSON/ORG/DATE/PHONE等'),
  1006. ('node', 'ENTITY', 'business_label', '业务标签', 'text', false, '业务含义标签'),
  1007. ('node', 'ENTITY', 'confidence', '置信度', 'number', false, 'NER识别置信度'),
  1008. ('node', 'ENTITY', 'occurrence_count', '出现次数', 'number', false, '在文档中出现次数'),
  1009. -- USER 节点属性
  1010. ('node', 'USER', 'email', '邮箱', 'text', false, '用户邮箱'),
  1011. ('node', 'USER', 'phone', '手机号', 'text', false, '用户手机号'),
  1012. ('node', 'USER', 'department', '部门', 'text', false, '所属部门'),
  1013. -- PROJECT 节点属性
  1014. ('node', 'PROJECT', 'description', '描述', 'text', false, '项目描述'),
  1015. ('node', 'PROJECT', 'start_date', '开始日期', 'date', false, '项目开始日期'),
  1016. ('node', 'PROJECT', 'end_date', '结束日期', 'date', false, '项目结束日期'),
  1017. -- INPUT_FROM 关系属性
  1018. ('edge', 'INPUT_FROM', 'input_key', '输入键', 'text', true, '输入参数标识'),
  1019. ('edge', 'INPUT_FROM', 'input_name', '输入名称', 'text', false, '输入参数显示名'),
  1020. ('edge', 'INPUT_FROM', 'input_type', '输入类型', 'text', false, 'entity_ref/value_ref/fixed'),
  1021. ('edge', 'INPUT_FROM', 'fixed_value', '固定值', 'text', false, '固定值(当input_type=fixed时)');
  1022. -- 4.4 初始化角色
  1023. INSERT INTO sys_roles (role_code, role_name, description, sort_order) VALUES
  1024. ('super_admin', '超级管理员', '系统最高权限,可管理所有功能', 1),
  1025. ('admin', '管理员', '可管理用户、项目、模板等', 2),
  1026. ('editor', '编辑员', '可编辑报告、管理附件', 3),
  1027. ('viewer', '查看者', '只读权限', 4);
  1028. -- 4.5 初始化权限(菜单+按钮)
  1029. INSERT INTO sys_permissions (perm_code, perm_name, perm_type, parent_id, path, icon, sort_order) VALUES
  1030. -- 一级菜单
  1031. ('dashboard', '工作台', 'menu', NULL, '/dashboard', 'Dashboard', 1),
  1032. ('project', '项目管理', 'menu', NULL, '/project', 'Folder', 2),
  1033. ('template', '模板管理', 'menu', NULL, '/template', 'FileText', 3),
  1034. ('report', '报告管理', 'menu', NULL, '/report', 'File', 4),
  1035. ('system', '系统管理', 'menu', NULL, '/system', 'Settings', 5);
  1036. INSERT INTO sys_permissions (perm_code, perm_name, perm_type, parent_id, path, component, sort_order) VALUES
  1037. -- 项目管理子菜单
  1038. ('project:list', '项目列表', 'menu', (SELECT id FROM sys_permissions WHERE perm_code = 'project'), '/project/list', 'project/List', 1),
  1039. ('project:create', '创建项目', 'button', (SELECT id FROM sys_permissions WHERE perm_code = 'project'), NULL, NULL, 2),
  1040. ('project:edit', '编辑项目', 'button', (SELECT id FROM sys_permissions WHERE perm_code = 'project'), NULL, NULL, 3),
  1041. ('project:delete', '删除项目', 'button', (SELECT id FROM sys_permissions WHERE perm_code = 'project'), NULL, NULL, 4),
  1042. -- 模板管理子菜单
  1043. ('template:list', '模板列表', 'menu', (SELECT id FROM sys_permissions WHERE perm_code = 'template'), '/template/list', 'template/List', 1),
  1044. ('template:create', '创建模板', 'button', (SELECT id FROM sys_permissions WHERE perm_code = 'template'), NULL, NULL, 2),
  1045. ('template:edit', '编辑模板', 'button', (SELECT id FROM sys_permissions WHERE perm_code = 'template'), NULL, NULL, 3),
  1046. ('template:delete', '删除模板', 'button', (SELECT id FROM sys_permissions WHERE perm_code = 'template'), NULL, NULL, 4),
  1047. -- 报告管理子菜单
  1048. ('report:list', '报告列表', 'menu', (SELECT id FROM sys_permissions WHERE perm_code = 'report'), '/report/list', 'report/List', 1),
  1049. ('report:create', '创建报告', 'button', (SELECT id FROM sys_permissions WHERE perm_code = 'report'), NULL, NULL, 2),
  1050. ('report:edit', '编辑报告', 'button', (SELECT id FROM sys_permissions WHERE perm_code = 'report'), NULL, NULL, 3),
  1051. ('report:delete', '删除报告', 'button', (SELECT id FROM sys_permissions WHERE perm_code = 'report'), NULL, NULL, 4),
  1052. ('report:export', '导出报告', 'button', (SELECT id FROM sys_permissions WHERE perm_code = 'report'), NULL, NULL, 5),
  1053. -- 系统管理子菜单
  1054. ('system:user', '用户管理', 'menu', (SELECT id FROM sys_permissions WHERE perm_code = 'system'), '/system/user', 'system/User', 1),
  1055. ('system:role', '角色管理', 'menu', (SELECT id FROM sys_permissions WHERE perm_code = 'system'), '/system/role', 'system/Role', 2),
  1056. ('system:config', '系统配置', 'menu', (SELECT id FROM sys_permissions WHERE perm_code = 'system'), '/system/config', 'system/Config', 3),
  1057. ('system:dict', '数据字典', 'menu', (SELECT id FROM sys_permissions WHERE perm_code = 'system'), '/system/dict', 'system/Dict', 4),
  1058. ('system:log', '操作日志', 'menu', (SELECT id FROM sys_permissions WHERE perm_code = 'system'), '/system/log', 'system/Log', 5);
  1059. -- 4.6 角色权限关联(超级管理员拥有所有权限)
  1060. INSERT INTO sys_role_permissions (role_id, permission_id)
  1061. SELECT (SELECT id FROM sys_roles WHERE role_code = 'super_admin'), id FROM sys_permissions;
  1062. -- 4.7 管理员权限(除系统管理外)
  1063. INSERT INTO sys_role_permissions (role_id, permission_id)
  1064. SELECT (SELECT id FROM sys_roles WHERE role_code = 'admin'), id FROM sys_permissions
  1065. WHERE perm_code NOT LIKE 'system:%' OR perm_code IN ('system:user', 'system:dict');
  1066. -- 4.8 编辑员权限
  1067. INSERT INTO sys_role_permissions (role_id, permission_id)
  1068. SELECT (SELECT id FROM sys_roles WHERE role_code = 'editor'), id FROM sys_permissions
  1069. WHERE perm_code IN ('dashboard', 'project', 'project:list', 'template', 'template:list',
  1070. 'report', 'report:list', 'report:create', 'report:edit', 'report:export');
  1071. -- 4.9 查看者权限
  1072. INSERT INTO sys_role_permissions (role_id, permission_id)
  1073. SELECT (SELECT id FROM sys_roles WHERE role_code = 'viewer'), id FROM sys_permissions
  1074. WHERE perm_code IN ('dashboard', 'project', 'project:list', 'template', 'template:list', 'report', 'report:list');
  1075. -- 4.10 初始化管理员用户(密码: admin123,实际部署时需修改)
  1076. -- 注:password_hash 使用 bcrypt 加密,此处为示例值
  1077. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1, 'USER', 'USR-001', '管理员', 'active', NULL);
  1078. INSERT INTO sys_users (node_id, username, password_hash, salt, real_name, department, status) VALUES
  1079. (1, 'admin', '$2a$10$N.zmdr9k7uOCQb376NoUnuTJ8iAt6Z5EHsM8lE9lBOsl7iAt6Z5EH', 'random_salt', '管理员', '技术部', 'active');
  1080. -- 4.11 管理员角色关联
  1081. INSERT INTO sys_user_roles (user_id, role_id) VALUES
  1082. (1, (SELECT id FROM sys_roles WHERE role_code = 'super_admin'));
  1083. -- 4.12 初始化系统配置
  1084. INSERT INTO sys_configs (config_key, config_value, config_type, description, is_public) VALUES
  1085. ('site_name', '灵越智报 2.0', 'string', '系统名称', true),
  1086. ('site_logo', '/assets/logo.png', 'string', '系统Logo', true),
  1087. ('upload_max_size', '52428800', 'number', '上传文件大小限制(字节)', false),
  1088. ('upload_allowed_types','docx,doc,pdf,xlsx,xls,png,jpg', 'string', '允许上传的文件类型', false),
  1089. ('session_timeout', '7200', 'number', '会话超时时间(秒)', false),
  1090. ('llm_api_url', 'https://api.openai.com/v1', 'string', 'LLM API地址', false),
  1091. ('llm_model', 'gpt-4', 'string', 'LLM模型名称', false);
  1092. -- 4.13 初始化数据字典
  1093. INSERT INTO sys_dict_types (dict_code, dict_name, description) VALUES
  1094. ('parse_status', '解析状态', '文件解析状态'),
  1095. ('element_type', '要素类型', '动态要素类型'),
  1096. ('rule_type', '规则类型', '规则类型'),
  1097. ('action_type', '动作类型', '规则动作类型'),
  1098. ('fill_source', '填充来源', '要素值填充来源'),
  1099. ('entity_type', '实体类型', 'NER实体类型'),
  1100. ('task_status', '任务状态', '异步任务状态');
  1101. INSERT INTO sys_dict_items (dict_type_id, item_code, item_name, sort_order) VALUES
  1102. -- 解析状态
  1103. ((SELECT id FROM sys_dict_types WHERE dict_code = 'parse_status'), 'pending', '待解析', 1),
  1104. ((SELECT id FROM sys_dict_types WHERE dict_code = 'parse_status'), 'parsing', '解析中', 2),
  1105. ((SELECT id FROM sys_dict_types WHERE dict_code = 'parse_status'), 'completed', '已完成', 3),
  1106. ((SELECT id FROM sys_dict_types WHERE dict_code = 'parse_status'), 'failed', '解析失败', 4),
  1107. -- 要素类型
  1108. ((SELECT id FROM sys_dict_types WHERE dict_code = 'element_type'), 'text', '文本', 1),
  1109. ((SELECT id FROM sys_dict_types WHERE dict_code = 'element_type'), 'paragraph', '段落', 2),
  1110. ((SELECT id FROM sys_dict_types WHERE dict_code = 'element_type'), 'table', '表格', 3),
  1111. -- 规则类型
  1112. ((SELECT id FROM sys_dict_types WHERE dict_code = 'rule_type'), 'extract', '提取', 1),
  1113. ((SELECT id FROM sys_dict_types WHERE dict_code = 'rule_type'), 'aggregate', '聚合', 2),
  1114. ((SELECT id FROM sys_dict_types WHERE dict_code = 'rule_type'), 'calculate', '计算', 3),
  1115. -- 动作类型
  1116. ((SELECT id FROM sys_dict_types WHERE dict_code = 'action_type'), 'llm', 'LLM调用', 1),
  1117. ((SELECT id FROM sys_dict_types WHERE dict_code = 'action_type'), 'script', '脚本执行', 2),
  1118. ((SELECT id FROM sys_dict_types WHERE dict_code = 'action_type'), 'lookup', '查表', 3),
  1119. -- 填充来源
  1120. ((SELECT id FROM sys_dict_types WHERE dict_code = 'fill_source'), 'manual', '手动填写', 1),
  1121. ((SELECT id FROM sys_dict_types WHERE dict_code = 'fill_source'), 'rule', '规则生成', 2),
  1122. ((SELECT id FROM sys_dict_types WHERE dict_code = 'fill_source'), 'default', '默认值', 3),
  1123. -- 实体类型
  1124. ((SELECT id FROM sys_dict_types WHERE dict_code = 'entity_type'), 'PERSON', '人名', 1),
  1125. ((SELECT id FROM sys_dict_types WHERE dict_code = 'entity_type'), 'ORG', '组织机构', 2),
  1126. ((SELECT id FROM sys_dict_types WHERE dict_code = 'entity_type'), 'DATE', '日期', 3),
  1127. ((SELECT id FROM sys_dict_types WHERE dict_code = 'entity_type'), 'PHONE', '电话', 4),
  1128. ((SELECT id FROM sys_dict_types WHERE dict_code = 'entity_type'), 'LOC', '地点', 5),
  1129. -- 任务状态
  1130. ((SELECT id FROM sys_dict_types WHERE dict_code = 'task_status'), 'pending', '待执行', 1),
  1131. ((SELECT id FROM sys_dict_types WHERE dict_code = 'task_status'), 'running', '执行中', 2),
  1132. ((SELECT id FROM sys_dict_types WHERE dict_code = 'task_status'), 'success', '成功', 3),
  1133. ((SELECT id FROM sys_dict_types WHERE dict_code = 'task_status'), 'failed', '失败', 4);
  1134. -- ============================================================
  1135. -- 5. Mock数据 - nodes
  1136. -- ============================================================
  1137. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2, 'PROJECT', 'PRJ-001', '成都院-安全生产标准化复审报告', 'active', 1);
  1138. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (100, 'SOURCE_FILE', 'SF-001', '成都院复审报告样本.docx', 'active', 1);
  1139. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (101, 'TEMPLATE', 'TPL-001', '电力安全生产标准化复审报告模板', 'active', 1);
  1140. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1001, 'ELEMENT', 'basicInfo.projectCode', '项目编号', 'active', NULL);
  1141. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1002, 'ELEMENT', 'project.reviewObject', '评审对象', 'active', NULL);
  1142. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1003, 'ELEMENT', 'basicInfo.requestLevel', '申请级别', 'active', NULL);
  1143. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1004, 'ELEMENT', 'project.resultScore', '评审得分', 'active', NULL);
  1144. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1005, 'ELEMENT', 'project.resultLevel', '评审级别', 'active', NULL);
  1145. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1006, 'ELEMENT', 'project.workStartAt', '评审开始日期', 'active', NULL);
  1146. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1007, 'ELEMENT', 'project.workEndAt', '评审结束日期', 'active', NULL);
  1147. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1008, 'ELEMENT', 'project.createdAt', '报告日期', 'active', NULL);
  1148. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1009, 'ELEMENT', 'project.reviewObjectSummary', '评审对象简介(前言)', 'active', NULL);
  1149. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1010, 'ELEMENT', 'project.reviewObjectAlias', '评审对象简称', 'active', NULL);
  1150. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1011, 'ELEMENT', 'basicInfo.reviewObjectCertificate2GetAt', '首次达标证书获取日期', 'active', NULL);
  1151. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1012, 'ELEMENT', 'basicInfo.reviewObjectCertificateGetAt', '证书获取日期', 'active', NULL);
  1152. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1013, 'ELEMENT', 'basicInfo.reviewObjectCertificateCode', '证书编号', 'active', NULL);
  1153. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1014, 'ELEMENT', 'basicInfo.applyAt', '申请日期', 'active', NULL);
  1154. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1015, 'ELEMENT', 'project.reviewPeriod', '评审期', 'active', NULL);
  1155. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1016, 'ELEMENT', 'project.reviewObjectDescription', '企业简介', 'active', NULL);
  1156. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1017, 'ELEMENT', 'project.target', '目标', 'active', NULL);
  1157. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1018, 'ELEMENT', 'project.duty', '组织机构和职责', 'active', NULL);
  1158. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1019, 'ELEMENT', 'project.fullParticipation', '全员参与', 'active', NULL);
  1159. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1020, 'ELEMENT', 'project.safetyInvestment', '安全生产投入', 'active', NULL);
  1160. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1021, 'ELEMENT', 'project.safetyCulture', '安全文化建设', 'active', NULL);
  1161. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1022, 'ELEMENT', 'project.systematicManagement', '制度化管理', 'active', NULL);
  1162. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1023, 'ELEMENT', 'project.employeeTraining', '人员教育培训', 'active', NULL);
  1163. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1024, 'ELEMENT', 'project.assetManagement', '设备设施管理', 'active', NULL);
  1164. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1025, 'ELEMENT', 'project.jobSafety', '作业安全', 'active', NULL);
  1165. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1026, 'ELEMENT', 'project.positionQualified', '岗位达标', 'active', NULL);
  1166. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1027, 'ELEMENT', 'project.partner', '相关方', 'active', NULL);
  1167. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1028, 'ELEMENT', 'project.occupationalHealth', '职业健康', 'active', NULL);
  1168. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1029, 'ELEMENT', 'project.riskAssessment', '风险辨识与评价', 'active', NULL);
  1169. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1030, 'ELEMENT', 'project.majorHazardManagement', '重大危险源管理', 'active', NULL);
  1170. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1031, 'ELEMENT', 'project.hazardInspection', '隐患排查', 'active', NULL);
  1171. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1032, 'ELEMENT', 'project.changeManagement', '变更管理', 'active', NULL);
  1172. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1033, 'ELEMENT', 'project.earlyWarning', '预测预警', 'active', NULL);
  1173. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1034, 'ELEMENT', 'project.emergencyResponse', '应急救援', 'active', NULL);
  1174. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1035, 'ELEMENT', 'project.incidentManagement', '事故管理', 'active', NULL);
  1175. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1036, 'ELEMENT', 'project.continuousImprovement', '持续改进', 'active', NULL);
  1176. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1037, 'ELEMENT', 'project.safetyStandardizationStatus', '安全生产标准化建设和持续运行情况', 'active', NULL);
  1177. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1038, 'ELEMENT', 'project.safetyHighlight', '安全生产管理亮点', 'active', NULL);
  1178. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1039, 'ELEMENT', 'project.reviewObjectSelfAssessmentProcess', '自评过程', 'active', NULL);
  1179. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1040, 'ELEMENT', 'project.moreWorkReference', '补充工作依据', 'active', NULL);
  1180. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1041, 'ELEMENT', 'project.reviewRange', '复审范围', 'active', NULL);
  1181. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1042, 'ELEMENT', 'project.workProcess', '现场复审工作过程', 'active', NULL);
  1182. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1043, 'ELEMENT', 'project.closingMeetingAt', '末次会议时间', 'active', NULL);
  1183. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1044, 'ELEMENT', 'SPSRRReviewProject', '现场复审项目选择(表格)', 'active', NULL);
  1184. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1045, 'ELEMENT', 'SPSRRReviewer', '现场复审人员(表格)', 'active', NULL);
  1185. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1046, 'ELEMENT', 'review_status', '现场复审情况(表格)', 'active', NULL);
  1186. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (1047, 'ELEMENT', 'target_responsibility', '目标职责复审情况(表格)', 'active', NULL);
  1187. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (200, 'REPORT', 'RPT-001', '成都院2024年安全生产标准化复审报告', 'draft', 1);
  1188. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2001, 'VALUE', 'RPT-001:basicInfo.projectCode', '项目编号值', 'active', NULL);
  1189. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2002, 'VALUE', 'RPT-001:project.reviewObject', '评审对象值', 'active', NULL);
  1190. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2003, 'VALUE', 'RPT-001:basicInfo.requestLevel', '申请级别值', 'active', NULL);
  1191. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2004, 'VALUE', 'RPT-001:project.resultScore', '评审得分值', 'active', NULL);
  1192. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2005, 'VALUE', 'RPT-001:project.resultLevel', '评审级别值', 'active', NULL);
  1193. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2006, 'VALUE', 'RPT-001:project.workStartAt', '评审开始日期值', 'active', NULL);
  1194. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2007, 'VALUE', 'RPT-001:project.workEndAt', '评审结束日期值', 'active', NULL);
  1195. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2008, 'VALUE', 'RPT-001:project.createdAt', '报告日期值', 'active', NULL);
  1196. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2009, 'VALUE', 'RPT-001:project.reviewObjectSummary', '评审对象简介值', 'active', NULL);
  1197. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2010, 'VALUE', 'RPT-001:project.reviewObjectAlias', '评审对象简称值', 'active', NULL);
  1198. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2011, 'VALUE', 'RPT-001:basicInfo.reviewObjectCertificate2GetAt', '首次达标证书获取日期值', 'active', NULL);
  1199. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2012, 'VALUE', 'RPT-001:basicInfo.reviewObjectCertificateGetAt', '证书获取日期值', 'active', NULL);
  1200. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2013, 'VALUE', 'RPT-001:basicInfo.reviewObjectCertificateCode', '证书编号值', 'active', NULL);
  1201. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2014, 'VALUE', 'RPT-001:basicInfo.applyAt', '申请日期值', 'active', NULL);
  1202. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2015, 'VALUE', 'RPT-001:project.reviewPeriod', '评审期值', 'active', NULL);
  1203. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2016, 'VALUE', 'RPT-001:project.reviewObjectDescription', '企业简介值', 'active', NULL);
  1204. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2017, 'VALUE', 'RPT-001:project.target', '目标值', 'active', NULL);
  1205. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2018, 'VALUE', 'RPT-001:project.duty', '组织机构和职责值', 'active', NULL);
  1206. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2019, 'VALUE', 'RPT-001:project.fullParticipation', '全员参与值', 'active', NULL);
  1207. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2020, 'VALUE', 'RPT-001:project.safetyInvestment', '安全生产投入值', 'active', NULL);
  1208. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2021, 'VALUE', 'RPT-001:project.safetyCulture', '安全文化建设值', 'active', NULL);
  1209. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2022, 'VALUE', 'RPT-001:project.systematicManagement', '制度化管理值', 'active', NULL);
  1210. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2023, 'VALUE', 'RPT-001:project.employeeTraining', '人员教育培训值', 'active', NULL);
  1211. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2024, 'VALUE', 'RPT-001:project.assetManagement', '设备设施管理值', 'active', NULL);
  1212. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2025, 'VALUE', 'RPT-001:project.jobSafety', '作业安全值', 'active', NULL);
  1213. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2026, 'VALUE', 'RPT-001:project.positionQualified', '岗位达标值', 'active', NULL);
  1214. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2027, 'VALUE', 'RPT-001:project.partner', '相关方值', 'active', NULL);
  1215. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2028, 'VALUE', 'RPT-001:project.occupationalHealth', '职业健康值', 'active', NULL);
  1216. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2029, 'VALUE', 'RPT-001:project.riskAssessment', '风险辨识与评价值', 'active', NULL);
  1217. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2030, 'VALUE', 'RPT-001:project.majorHazardManagement', '重大危险源管理值', 'active', NULL);
  1218. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2031, 'VALUE', 'RPT-001:project.hazardInspection', '隐患排查值', 'active', NULL);
  1219. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2032, 'VALUE', 'RPT-001:project.changeManagement', '变更管理值', 'active', NULL);
  1220. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2033, 'VALUE', 'RPT-001:project.earlyWarning', '预测预警值', 'active', NULL);
  1221. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2034, 'VALUE', 'RPT-001:project.emergencyResponse', '应急救援值', 'active', NULL);
  1222. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2035, 'VALUE', 'RPT-001:project.incidentManagement', '事故管理值', 'active', NULL);
  1223. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2036, 'VALUE', 'RPT-001:project.continuousImprovement', '持续改进值', 'active', NULL);
  1224. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2037, 'VALUE', 'RPT-001:project.safetyStandardizationStatus', '安全生产标准化建设和持续运行情况值', 'active', NULL);
  1225. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2038, 'VALUE', 'RPT-001:project.safetyHighlight', '安全生产管理亮点值', 'active', NULL);
  1226. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2039, 'VALUE', 'RPT-001:project.reviewObjectSelfAssessmentProcess', '自评过程值', 'active', NULL);
  1227. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2040, 'VALUE', 'RPT-001:project.moreWorkReference', '补充工作依据值', 'active', NULL);
  1228. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2041, 'VALUE', 'RPT-001:project.reviewRange', '复审范围值', 'active', NULL);
  1229. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2042, 'VALUE', 'RPT-001:project.workProcess', '现场复审工作过程值', 'active', NULL);
  1230. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2043, 'VALUE', 'RPT-001:project.closingMeetingAt', '末次会议时间值', 'active', NULL);
  1231. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2044, 'VALUE', 'RPT-001:SPSRRReviewProject', '现场复审项目选择值', 'active', NULL);
  1232. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2045, 'VALUE', 'RPT-001:SPSRRReviewer', '现场复审人员值', 'active', NULL);
  1233. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2046, 'VALUE', 'RPT-001:review_status', '现场复审情况值', 'active', NULL);
  1234. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (2047, 'VALUE', 'RPT-001:target_responsibility', '目标职责复审情况值', 'active', NULL);
  1235. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (300, 'REPORT', 'RPT-002', '华东院2024年安全生产标准化复审报告', 'draft', 1);
  1236. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (400, 'ATTACHMENT', 'ATT-001', '现场检测点位布置图', 'active', NULL);
  1237. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (401, 'ATTACHMENT', 'ATT-002', '现场检测照片', 'active', NULL);
  1238. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (402, 'ATTACHMENT', 'ATT-003', '检测计划与检测方案', 'active', NULL);
  1239. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (403, 'ATTACHMENT', 'ATT-004', '工况记录表', 'active', NULL);
  1240. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (404, 'ATTACHMENT', 'ATT-005', '噪声检测原始记录表', 'active', NULL);
  1241. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (405, 'ATTACHMENT', 'ATT-006', '工频电场、工频磁场检测原始记录表', 'active', NULL);
  1242. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (500, 'ENTITY', 'ENT-001', '中国电建集团成都勘测设计研究院有限公司', 'active', NULL);
  1243. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (501, 'ENTITY', 'ENT-002', '中国电力建设集团(股份)有限公司', 'active', NULL);
  1244. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (502, 'ENTITY', 'ENT-003', '湖北安源安全环保科技有限公司', 'active', NULL);
  1245. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (503, 'ENTITY', 'ENT-004', '成都院', 'active', NULL);
  1246. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (504, 'ENTITY', 'ENT-005', 'BZ-0092-2024', 'active', NULL);
  1247. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (505, 'ENTITY', 'ENT-006', 'ZGDIDBOY-083', 'active', NULL);
  1248. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (506, 'ENTITY', 'ENT-007', '何彦锋', 'active', NULL);
  1249. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (507, 'ENTITY', 'ENT-008', '张世殊', 'active', NULL);
  1250. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (508, 'ENTITY', 'ENT-009', '鞠其凤', 'active', NULL);
  1251. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (509, 'ENTITY', 'ENT-010', '向林', 'active', NULL);
  1252. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (510, 'ENTITY', 'ENT-011', '刘建冰', 'active', NULL);
  1253. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (511, 'ENTITY', 'ENT-012', '93.33', 'active', NULL);
  1254. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (512, 'ENTITY', 'ENT-013', '一级', 'active', NULL);
  1255. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (513, 'ENTITY', 'ENT-014', '2024年7月13日', 'active', NULL);
  1256. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (514, 'ENTITY', 'ENT-015', '2024年10月17日', 'active', NULL);
  1257. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (515, 'ENTITY', 'ENT-016', '2024年7月8日', 'active', NULL);
  1258. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (516, 'ENTITY', 'ENT-017', '2019年12月9日', 'active', NULL);
  1259. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (517, 'ENTITY', 'ENT-018', '2023年7月8日至2024年7月7日', 'active', NULL);
  1260. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (518, 'ENTITY', 'ENT-019', '2024年11月', 'active', NULL);
  1261. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (519, 'ENTITY', 'ENT-020', '2019年', 'active', NULL);
  1262. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (520, 'ENTITY', 'ENT-021', '葛学福', 'active', NULL);
  1263. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (521, 'ENTITY', 'ENT-022', '余正坚', 'active', NULL);
  1264. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (522, 'ENTITY', 'ENT-023', '苏经仪', 'active', NULL);
  1265. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (523, 'ENTITY', 'ENT-024', '周建胜', 'active', NULL);
  1266. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (524, 'ENTITY', 'ENT-025', '赵泓', 'active', NULL);
  1267. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (525, 'ENTITY', 'ENT-026', '朱晓莉', 'active', NULL);
  1268. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (526, 'ENTITY', 'ENT-027', '向义', 'active', NULL);
  1269. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (600, 'RULE', 'RPT-001:basicInfo.projectCode', '项目编号提取规则', 'active', NULL);
  1270. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (601, 'RULE', 'RPT-001:project.reviewObject', '评审对象-直接引用实体', 'active', NULL);
  1271. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (602, 'RULE', 'RPT-001:project.resultScore', '评审得分提取规则', 'active', NULL);
  1272. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (603, 'RULE', 'RPT-001:project.reviewObjectAlias', '评审对象简称-直接引用实体', 'active', NULL);
  1273. INSERT INTO nodes (id, node_type, node_key, name, status, created_by) VALUES (604, 'RULE', 'RPT-001:basicInfo.requestLevel', '申请级别-直接引用实体', 'active', NULL);
  1274. -- 重置序列
  1275. SELECT setval('nodes_id_seq', (SELECT MAX(id) FROM nodes));
  1276. -- ============================================================
  1277. -- 6. Mock数据 - edges
  1278. -- ============================================================
  1279. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (1, 'CREATED_BY', 2, 1, 0); -- 项目 → 用户
  1280. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (2, 'CREATED_BY', 100, 1, 0); -- 样本文件 → 用户
  1281. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (3, 'CREATED_BY', 200, 1, 0); -- 成都院报告 → 用户
  1282. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (10, 'PARSED_TO', 100, 101, 0); -- 样本文件 → 模板
  1283. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (20, 'HAS_ELEMENT', 101, 1001, 1);
  1284. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (21, 'HAS_ELEMENT', 101, 1002, 2);
  1285. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (22, 'HAS_ELEMENT', 101, 1003, 3);
  1286. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (23, 'HAS_ELEMENT', 101, 1004, 4);
  1287. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (24, 'HAS_ELEMENT', 101, 1005, 5);
  1288. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (25, 'HAS_ELEMENT', 101, 1006, 6);
  1289. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (26, 'HAS_ELEMENT', 101, 1007, 7);
  1290. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (27, 'HAS_ELEMENT', 101, 1008, 8);
  1291. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (28, 'HAS_ELEMENT', 101, 1009, 9);
  1292. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (29, 'HAS_ELEMENT', 101, 1010, 10);
  1293. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (30, 'HAS_ELEMENT', 101, 1011, 11);
  1294. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (31, 'HAS_ELEMENT', 101, 1012, 12);
  1295. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (32, 'HAS_ELEMENT', 101, 1013, 13);
  1296. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (33, 'HAS_ELEMENT', 101, 1014, 14);
  1297. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (34, 'HAS_ELEMENT', 101, 1015, 15);
  1298. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (35, 'HAS_ELEMENT', 101, 1016, 16);
  1299. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (36, 'HAS_ELEMENT', 101, 1017, 17);
  1300. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (37, 'HAS_ELEMENT', 101, 1018, 18);
  1301. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (38, 'HAS_ELEMENT', 101, 1019, 19);
  1302. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (39, 'HAS_ELEMENT', 101, 1020, 20);
  1303. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (40, 'HAS_ELEMENT', 101, 1021, 21);
  1304. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (41, 'HAS_ELEMENT', 101, 1022, 22);
  1305. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (42, 'HAS_ELEMENT', 101, 1023, 23);
  1306. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (43, 'HAS_ELEMENT', 101, 1024, 24);
  1307. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (44, 'HAS_ELEMENT', 101, 1025, 25);
  1308. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (45, 'HAS_ELEMENT', 101, 1026, 26);
  1309. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (46, 'HAS_ELEMENT', 101, 1027, 27);
  1310. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (47, 'HAS_ELEMENT', 101, 1028, 28);
  1311. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (48, 'HAS_ELEMENT', 101, 1029, 29);
  1312. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (49, 'HAS_ELEMENT', 101, 1030, 30);
  1313. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (50, 'HAS_ELEMENT', 101, 1031, 31);
  1314. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (51, 'HAS_ELEMENT', 101, 1032, 32);
  1315. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (52, 'HAS_ELEMENT', 101, 1033, 33);
  1316. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (53, 'HAS_ELEMENT', 101, 1034, 34);
  1317. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (54, 'HAS_ELEMENT', 101, 1035, 35);
  1318. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (55, 'HAS_ELEMENT', 101, 1036, 36);
  1319. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (56, 'HAS_ELEMENT', 101, 1037, 37);
  1320. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (57, 'HAS_ELEMENT', 101, 1038, 38);
  1321. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (58, 'HAS_ELEMENT', 101, 1039, 39);
  1322. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (59, 'HAS_ELEMENT', 101, 1040, 40);
  1323. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (60, 'HAS_ELEMENT', 101, 1041, 41);
  1324. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (61, 'HAS_ELEMENT', 101, 1042, 42);
  1325. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (62, 'HAS_ELEMENT', 101, 1043, 43);
  1326. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (63, 'HAS_ELEMENT', 101, 1044, 44);
  1327. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (64, 'HAS_ELEMENT', 101, 1045, 45);
  1328. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (65, 'HAS_ELEMENT', 101, 1046, 46);
  1329. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (66, 'HAS_ELEMENT', 101, 1047, 47);
  1330. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (100, 'INSTANCE_OF', 200, 101, 0); -- 成都院报告 → 模板
  1331. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (101, 'BELONGS_TO', 200, 2, 0); -- 成都院报告 → 项目
  1332. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (200, 'HAS_VALUE', 200, 2001, 1);
  1333. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (201, 'HAS_VALUE', 200, 2002, 2);
  1334. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (202, 'HAS_VALUE', 200, 2003, 3);
  1335. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (203, 'HAS_VALUE', 200, 2004, 4);
  1336. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (204, 'HAS_VALUE', 200, 2005, 5);
  1337. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (205, 'HAS_VALUE', 200, 2006, 6);
  1338. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (206, 'HAS_VALUE', 200, 2007, 7);
  1339. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (207, 'HAS_VALUE', 200, 2008, 8);
  1340. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (208, 'HAS_VALUE', 200, 2009, 9);
  1341. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (209, 'HAS_VALUE', 200, 2010, 10);
  1342. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (210, 'HAS_VALUE', 200, 2011, 11);
  1343. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (211, 'HAS_VALUE', 200, 2012, 12);
  1344. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (212, 'HAS_VALUE', 200, 2013, 13);
  1345. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (213, 'HAS_VALUE', 200, 2014, 14);
  1346. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (214, 'HAS_VALUE', 200, 2015, 15);
  1347. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (215, 'HAS_VALUE', 200, 2016, 16);
  1348. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (216, 'HAS_VALUE', 200, 2017, 17);
  1349. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (217, 'HAS_VALUE', 200, 2018, 18);
  1350. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (218, 'HAS_VALUE', 200, 2019, 19);
  1351. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (219, 'HAS_VALUE', 200, 2020, 20);
  1352. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (220, 'HAS_VALUE', 200, 2021, 21);
  1353. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (221, 'HAS_VALUE', 200, 2022, 22);
  1354. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (222, 'HAS_VALUE', 200, 2023, 23);
  1355. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (223, 'HAS_VALUE', 200, 2024, 24);
  1356. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (224, 'HAS_VALUE', 200, 2025, 25);
  1357. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (225, 'HAS_VALUE', 200, 2026, 26);
  1358. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (226, 'HAS_VALUE', 200, 2027, 27);
  1359. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (227, 'HAS_VALUE', 200, 2028, 28);
  1360. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (228, 'HAS_VALUE', 200, 2029, 29);
  1361. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (229, 'HAS_VALUE', 200, 2030, 30);
  1362. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (230, 'HAS_VALUE', 200, 2031, 31);
  1363. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (231, 'HAS_VALUE', 200, 2032, 32);
  1364. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (232, 'HAS_VALUE', 200, 2033, 33);
  1365. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (233, 'HAS_VALUE', 200, 2034, 34);
  1366. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (234, 'HAS_VALUE', 200, 2035, 35);
  1367. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (235, 'HAS_VALUE', 200, 2036, 36);
  1368. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (236, 'HAS_VALUE', 200, 2037, 37);
  1369. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (237, 'HAS_VALUE', 200, 2038, 38);
  1370. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (238, 'HAS_VALUE', 200, 2039, 39);
  1371. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (239, 'HAS_VALUE', 200, 2040, 40);
  1372. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (240, 'HAS_VALUE', 200, 2041, 41);
  1373. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (241, 'HAS_VALUE', 200, 2042, 42);
  1374. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (242, 'HAS_VALUE', 200, 2043, 43);
  1375. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (243, 'HAS_VALUE', 200, 2044, 44);
  1376. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (244, 'HAS_VALUE', 200, 2045, 45);
  1377. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (245, 'HAS_VALUE', 200, 2046, 46);
  1378. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (246, 'HAS_VALUE', 200, 2047, 47);
  1379. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (300, 'FOR_ELEMENT', 2001, 1001, 0);
  1380. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (301, 'FOR_ELEMENT', 2002, 1002, 0);
  1381. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (302, 'FOR_ELEMENT', 2003, 1003, 0);
  1382. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (303, 'FOR_ELEMENT', 2004, 1004, 0);
  1383. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (304, 'FOR_ELEMENT', 2005, 1005, 0);
  1384. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (305, 'FOR_ELEMENT', 2006, 1006, 0);
  1385. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (306, 'FOR_ELEMENT', 2007, 1007, 0);
  1386. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (307, 'FOR_ELEMENT', 2008, 1008, 0);
  1387. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (308, 'FOR_ELEMENT', 2009, 1009, 0);
  1388. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (309, 'FOR_ELEMENT', 2010, 1010, 0);
  1389. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (310, 'FOR_ELEMENT', 2011, 1011, 0);
  1390. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (311, 'FOR_ELEMENT', 2012, 1012, 0);
  1391. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (312, 'FOR_ELEMENT', 2013, 1013, 0);
  1392. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (313, 'FOR_ELEMENT', 2014, 1014, 0);
  1393. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (314, 'FOR_ELEMENT', 2015, 1015, 0);
  1394. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (315, 'FOR_ELEMENT', 2016, 1016, 0);
  1395. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (316, 'FOR_ELEMENT', 2017, 1017, 0);
  1396. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (317, 'FOR_ELEMENT', 2018, 1018, 0);
  1397. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (318, 'FOR_ELEMENT', 2019, 1019, 0);
  1398. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (319, 'FOR_ELEMENT', 2020, 1020, 0);
  1399. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (320, 'FOR_ELEMENT', 2021, 1021, 0);
  1400. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (321, 'FOR_ELEMENT', 2022, 1022, 0);
  1401. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (322, 'FOR_ELEMENT', 2023, 1023, 0);
  1402. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (323, 'FOR_ELEMENT', 2024, 1024, 0);
  1403. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (324, 'FOR_ELEMENT', 2025, 1025, 0);
  1404. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (325, 'FOR_ELEMENT', 2026, 1026, 0);
  1405. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (326, 'FOR_ELEMENT', 2027, 1027, 0);
  1406. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (327, 'FOR_ELEMENT', 2028, 1028, 0);
  1407. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (328, 'FOR_ELEMENT', 2029, 1029, 0);
  1408. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (329, 'FOR_ELEMENT', 2030, 1030, 0);
  1409. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (330, 'FOR_ELEMENT', 2031, 1031, 0);
  1410. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (331, 'FOR_ELEMENT', 2032, 1032, 0);
  1411. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (332, 'FOR_ELEMENT', 2033, 1033, 0);
  1412. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (333, 'FOR_ELEMENT', 2034, 1034, 0);
  1413. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (334, 'FOR_ELEMENT', 2035, 1035, 0);
  1414. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (335, 'FOR_ELEMENT', 2036, 1036, 0);
  1415. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (336, 'FOR_ELEMENT', 2037, 1037, 0);
  1416. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (337, 'FOR_ELEMENT', 2038, 1038, 0);
  1417. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (338, 'FOR_ELEMENT', 2039, 1039, 0);
  1418. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (339, 'FOR_ELEMENT', 2040, 1040, 0);
  1419. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (340, 'FOR_ELEMENT', 2041, 1041, 0);
  1420. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (341, 'FOR_ELEMENT', 2042, 1042, 0);
  1421. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (342, 'FOR_ELEMENT', 2043, 1043, 0);
  1422. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (343, 'FOR_ELEMENT', 2044, 1044, 0);
  1423. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (344, 'FOR_ELEMENT', 2045, 1045, 0);
  1424. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (345, 'FOR_ELEMENT', 2046, 1046, 0);
  1425. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (346, 'FOR_ELEMENT', 2047, 1047, 0);
  1426. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (400, 'HAS_ATTACHMENT', 200, 400, 1);
  1427. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (401, 'HAS_ATTACHMENT', 200, 401, 2);
  1428. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (402, 'HAS_ATTACHMENT', 200, 402, 3);
  1429. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (403, 'HAS_ATTACHMENT', 200, 403, 4);
  1430. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (404, 'HAS_ATTACHMENT', 200, 404, 5);
  1431. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (405, 'HAS_ATTACHMENT', 200, 405, 6);
  1432. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (500, 'HAS_ENTITY', 100, 500, 1); -- 样本文件 → 实体
  1433. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (501, 'HAS_ENTITY', 100, 501, 2);
  1434. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (502, 'HAS_ENTITY', 100, 502, 3);
  1435. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (503, 'HAS_ENTITY', 100, 503, 4);
  1436. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (504, 'HAS_ENTITY', 100, 504, 5);
  1437. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (505, 'HAS_ENTITY', 100, 505, 6);
  1438. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (506, 'HAS_ENTITY', 100, 506, 7);
  1439. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (507, 'HAS_ENTITY', 100, 507, 8);
  1440. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (508, 'HAS_ENTITY', 100, 508, 9);
  1441. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (509, 'HAS_ENTITY', 100, 509, 10);
  1442. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (510, 'HAS_ENTITY', 100, 510, 11);
  1443. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (511, 'HAS_ENTITY', 100, 511, 12);
  1444. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (512, 'HAS_ENTITY', 100, 512, 13);
  1445. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (513, 'HAS_ENTITY', 100, 513, 14);
  1446. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (514, 'HAS_ENTITY', 100, 514, 15);
  1447. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (515, 'HAS_ENTITY', 100, 515, 16);
  1448. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (516, 'HAS_ENTITY', 100, 516, 17);
  1449. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (517, 'HAS_ENTITY', 100, 517, 18);
  1450. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (518, 'HAS_ENTITY', 100, 518, 19);
  1451. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (519, 'HAS_ENTITY', 100, 519, 20);
  1452. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (520, 'HAS_ENTITY', 100, 520, 21);
  1453. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (521, 'HAS_ENTITY', 100, 521, 22);
  1454. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (522, 'HAS_ENTITY', 100, 522, 23);
  1455. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (523, 'HAS_ENTITY', 100, 523, 24);
  1456. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (524, 'HAS_ENTITY', 100, 524, 25);
  1457. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (525, 'HAS_ENTITY', 100, 525, 26);
  1458. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (526, 'HAS_ENTITY', 100, 526, 27);
  1459. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (600, 'HAS_RULE', 200, 600, 1); -- 报告 → 规则
  1460. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (601, 'HAS_RULE', 200, 601, 2);
  1461. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (602, 'HAS_RULE', 200, 602, 3);
  1462. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (603, 'HAS_RULE', 200, 603, 4);
  1463. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (604, 'HAS_RULE', 200, 604, 5);
  1464. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (610, 'FOR_ELEMENT', 600, 1001, 0); -- 规则 → 要素
  1465. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (611, 'FOR_ELEMENT', 601, 1002, 0);
  1466. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (612, 'FOR_ELEMENT', 602, 1004, 0);
  1467. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (613, 'FOR_ELEMENT', 603, 1010, 0);
  1468. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (614, 'FOR_ELEMENT', 604, 1003, 0);
  1469. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (620, 'INPUT_FROM', 600, 100, 1); -- 规则输入 ← 样本文件
  1470. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (621, 'INPUT_FROM', 601, 500, 1); -- 规则输入 ← 实体(评审对象)
  1471. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (622, 'INPUT_FROM', 602, 100, 1); -- 规则输入 ← 样本文件
  1472. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (623, 'INPUT_FROM', 603, 503, 1); -- 规则输入 ← 实体(成都院)
  1473. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (624, 'INPUT_FROM', 604, 512, 1); -- 规则输入 ← 实体(一级)
  1474. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (700, 'INSTANCE_OF', 300, 101, 0); -- 华东院报告 → 模板
  1475. INSERT INTO edges (id, edge_type, from_node_id, to_node_id, sort_order) VALUES (701, 'COPIED_FROM', 300, 200, 0); -- 华东院报告 ← 成都院报告
  1476. -- 重置序列
  1477. SELECT setval('edges_id_seq', (SELECT MAX(id) FROM edges));
  1478. -- ============================================================
  1479. -- 7. Mock数据 - node_properties
  1480. -- ============================================================
  1481. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (100, 'original_name', '成都院复审报告样本.docx');
  1482. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (100, 'file_path', '/uploads/2026/02/SF-001.docx');
  1483. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (100, 'file_type', 'docx');
  1484. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_number) VALUES (100, 'file_size', NULL, 2048000);
  1485. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (100, 'parse_status', 'completed');
  1486. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (100, 'content_text', '[原文全文内容,见mock数据.txt第8-337行]');
  1487. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (101, 'template_code', 'TPL-SPSRR-2024');
  1488. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (101, 'category', '电力安全生产标准化复审');
  1489. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (101, 'content_template', '[模板全文内容,见mock数据.txt第338-516行]');
  1490. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1001, 'element_type', 'text');
  1491. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1001, 'namespace', 'basicInfo');
  1492. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1001, 'field_name', 'projectCode');
  1493. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1001, 'required', 'true');
  1494. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1002, 'element_type', 'text');
  1495. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1002, 'namespace', 'project');
  1496. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1002, 'field_name', 'reviewObject');
  1497. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1002, 'required', 'true');
  1498. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1003, 'element_type', 'text');
  1499. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1003, 'namespace', 'basicInfo');
  1500. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1003, 'field_name', 'requestLevel');
  1501. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1003, 'required', 'true');
  1502. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1004, 'element_type', 'text');
  1503. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1004, 'namespace', 'project');
  1504. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1004, 'field_name', 'resultScore');
  1505. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1004, 'required', 'true');
  1506. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1005, 'element_type', 'text');
  1507. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1005, 'namespace', 'project');
  1508. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1005, 'field_name', 'resultLevel');
  1509. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1005, 'required', 'true');
  1510. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1006, 'element_type', 'text');
  1511. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1006, 'namespace', 'project');
  1512. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1006, 'field_name', 'workStartAt');
  1513. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1006, 'required', 'true');
  1514. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1007, 'element_type', 'text');
  1515. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1007, 'namespace', 'project');
  1516. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1007, 'field_name', 'workEndAt');
  1517. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1007, 'required', 'true');
  1518. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1008, 'element_type', 'text');
  1519. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1008, 'namespace', 'project');
  1520. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1008, 'field_name', 'createdAt');
  1521. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1009, 'element_type', 'paragraph');
  1522. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1009, 'namespace', 'project');
  1523. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1009, 'field_name', 'reviewObjectSummary');
  1524. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1010, 'element_type', 'text');
  1525. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1010, 'namespace', 'project');
  1526. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1010, 'field_name', 'reviewObjectAlias');
  1527. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1010, 'required', 'true');
  1528. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1011, 'element_type', 'text');
  1529. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1011, 'namespace', 'basicInfo');
  1530. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1011, 'field_name', 'reviewObjectCertificate2GetAt');
  1531. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1012, 'element_type', 'text');
  1532. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1012, 'namespace', 'basicInfo');
  1533. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1012, 'field_name', 'reviewObjectCertificateGetAt');
  1534. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1013, 'element_type', 'text');
  1535. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1013, 'namespace', 'basicInfo');
  1536. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1013, 'field_name', 'reviewObjectCertificateCode');
  1537. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1014, 'element_type', 'text');
  1538. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1014, 'namespace', 'basicInfo');
  1539. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1014, 'field_name', 'applyAt');
  1540. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1015, 'element_type', 'text');
  1541. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1015, 'namespace', 'project');
  1542. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1015, 'field_name', 'reviewPeriod');
  1543. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1016, 'element_type', 'paragraph');
  1544. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1016, 'namespace', 'project');
  1545. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1016, 'field_name', 'reviewObjectDescription');
  1546. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1017, 'element_type', 'paragraph');
  1547. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1017, 'namespace', 'project');
  1548. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1017, 'field_name', 'target');
  1549. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1018, 'element_type', 'paragraph');
  1550. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1018, 'namespace', 'project');
  1551. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1018, 'field_name', 'duty');
  1552. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1019, 'element_type', 'paragraph');
  1553. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1019, 'namespace', 'project');
  1554. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1019, 'field_name', 'fullParticipation');
  1555. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1020, 'element_type', 'paragraph');
  1556. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1020, 'namespace', 'project');
  1557. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1020, 'field_name', 'safetyInvestment');
  1558. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1021, 'element_type', 'paragraph');
  1559. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1021, 'namespace', 'project');
  1560. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1021, 'field_name', 'safetyCulture');
  1561. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1022, 'element_type', 'paragraph');
  1562. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1022, 'namespace', 'project');
  1563. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1022, 'field_name', 'systematicManagement');
  1564. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1023, 'element_type', 'paragraph');
  1565. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1023, 'namespace', 'project');
  1566. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1023, 'field_name', 'employeeTraining');
  1567. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1024, 'element_type', 'paragraph');
  1568. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1024, 'namespace', 'project');
  1569. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1024, 'field_name', 'assetManagement');
  1570. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1025, 'element_type', 'paragraph');
  1571. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1025, 'namespace', 'project');
  1572. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1025, 'field_name', 'jobSafety');
  1573. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1026, 'element_type', 'paragraph');
  1574. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1026, 'namespace', 'project');
  1575. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1026, 'field_name', 'positionQualified');
  1576. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1027, 'element_type', 'paragraph');
  1577. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1027, 'namespace', 'project');
  1578. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1027, 'field_name', 'partner');
  1579. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1028, 'element_type', 'paragraph');
  1580. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1028, 'namespace', 'project');
  1581. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1028, 'field_name', 'occupationalHealth');
  1582. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1029, 'element_type', 'paragraph');
  1583. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1029, 'namespace', 'project');
  1584. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1029, 'field_name', 'riskAssessment');
  1585. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1030, 'element_type', 'paragraph');
  1586. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1030, 'namespace', 'project');
  1587. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1030, 'field_name', 'majorHazardManagement');
  1588. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1031, 'element_type', 'paragraph');
  1589. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1031, 'namespace', 'project');
  1590. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1031, 'field_name', 'hazardInspection');
  1591. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1032, 'element_type', 'paragraph');
  1592. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1032, 'namespace', 'project');
  1593. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1032, 'field_name', 'changeManagement');
  1594. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1033, 'element_type', 'paragraph');
  1595. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1033, 'namespace', 'project');
  1596. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1033, 'field_name', 'earlyWarning');
  1597. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1034, 'element_type', 'paragraph');
  1598. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1034, 'namespace', 'project');
  1599. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1034, 'field_name', 'emergencyResponse');
  1600. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1035, 'element_type', 'paragraph');
  1601. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1035, 'namespace', 'project');
  1602. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1035, 'field_name', 'incidentManagement');
  1603. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1036, 'element_type', 'paragraph');
  1604. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1036, 'namespace', 'project');
  1605. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1036, 'field_name', 'continuousImprovement');
  1606. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1037, 'element_type', 'paragraph');
  1607. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1037, 'namespace', 'project');
  1608. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1037, 'field_name', 'safetyStandardizationStatus');
  1609. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1038, 'element_type', 'paragraph');
  1610. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1038, 'namespace', 'project');
  1611. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1038, 'field_name', 'safetyHighlight');
  1612. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1039, 'element_type', 'paragraph');
  1613. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1039, 'namespace', 'project');
  1614. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1039, 'field_name', 'reviewObjectSelfAssessmentProcess');
  1615. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1040, 'element_type', 'text');
  1616. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1040, 'namespace', 'project');
  1617. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1040, 'field_name', 'moreWorkReference');
  1618. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1041, 'element_type', 'text');
  1619. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1041, 'namespace', 'project');
  1620. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1041, 'field_name', 'reviewRange');
  1621. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1042, 'element_type', 'paragraph');
  1622. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1042, 'namespace', 'project');
  1623. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1042, 'field_name', 'workProcess');
  1624. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1043, 'element_type', 'text');
  1625. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1043, 'namespace', 'project');
  1626. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1043, 'field_name', 'closingMeetingAt');
  1627. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1044, 'element_type', 'table');
  1628. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1044, 'namespace', 'SPSRRReviewProject');
  1629. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1044, 'field_name', 'SPSRRReviewProject');
  1630. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1045, 'element_type', 'table');
  1631. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1045, 'namespace', 'SPSRRReviewer');
  1632. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1045, 'field_name', 'SPSRRReviewer');
  1633. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1046, 'element_type', 'table');
  1634. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1046, 'namespace', 'review_status');
  1635. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1046, 'field_name', 'review_status');
  1636. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1047, 'element_type', 'table');
  1637. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1047, 'namespace', 'target_responsibility');
  1638. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (1047, 'field_name', 'target_responsibility');
  1639. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (200, 'report_code', 'RPT-SPSRR-CDY-2024');
  1640. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (200, 'title', '中国电建集团成都勘测设计研究院有限公司安全生产标准化复审报告');
  1641. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2001, 'value_text', 'BZ-0092-2024');
  1642. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2001, 'is_filled', 'true');
  1643. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2001, 'fill_source', 'rule');
  1644. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2002, 'value_text', '中国电建集团成都勘测设计研究院有限公司');
  1645. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2002, 'is_filled', 'true');
  1646. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2002, 'fill_source', 'rule');
  1647. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2003, 'value_text', '一级');
  1648. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2003, 'is_filled', 'true');
  1649. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2003, 'fill_source', 'rule');
  1650. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2004, 'value_text', '93.33');
  1651. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2004, 'is_filled', 'true');
  1652. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2004, 'fill_source', 'rule');
  1653. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2005, 'value_text', '一级');
  1654. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2005, 'is_filled', 'true');
  1655. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2005, 'fill_source', 'manual');
  1656. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2006, 'value_text', '2024年7月13日');
  1657. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2006, 'is_filled', 'true');
  1658. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2006, 'fill_source', 'manual');
  1659. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2007, 'value_text', '2024年10月17日');
  1660. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2007, 'is_filled', 'true');
  1661. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2007, 'fill_source', 'manual');
  1662. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2008, 'value_text', '2024年11月');
  1663. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2008, 'is_filled', 'true');
  1664. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2008, 'fill_source', 'manual');
  1665. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2009, 'value_text', '中国电建集团成都勘测设计研究院有限公司(以下简称"成都院"或"公司")是中国电力建设集团(股份)有限公司(以下简称"股份公司")的全资子企业,其历史可以追溯至1950年成立的燃料工业部西南水力发电工程处,建制于1955年成立的电力工业部成都勘测设计局。经过70多年发展壮大,已成为在能源电力、水资源与环境、城市建设与基础设施等领域,为全球客户提供规划咨询、勘测设计、施工建造、投资运营全产业链一体化综合服务的大型综合性勘测设计研究单位。成都院致力于为全球清洁能源工程及基础设施、环境工程提供系统产品与整体解决方案和服务,技术实力始终保持行业领先地位。');
  1666. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2009, 'is_filled', 'true');
  1667. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2009, 'fill_source', 'manual');
  1668. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2010, 'value_text', '成都院');
  1669. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2010, 'is_filled', 'true');
  1670. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2010, 'fill_source', 'rule');
  1671. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2011, 'value_text', '2019年');
  1672. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2011, 'is_filled', 'true');
  1673. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2011, 'fill_source', 'manual');
  1674. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2012, 'value_text', '2019年12月9日');
  1675. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2012, 'is_filled', 'true');
  1676. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2012, 'fill_source', 'manual');
  1677. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2013, 'value_text', 'ZGDIDBOY-083');
  1678. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2013, 'is_filled', 'true');
  1679. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2013, 'fill_source', 'manual');
  1680. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2014, 'value_text', '2024年7月8日');
  1681. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2014, 'is_filled', 'true');
  1682. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2014, 'fill_source', 'manual');
  1683. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2015, 'value_text', '2023年7月8日至2024年7月7日');
  1684. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2015, 'is_filled', 'true');
  1685. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2015, 'fill_source', 'manual');
  1686. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2016, 'value_text', '中国电建集团成都勘测设计研究院有限公司为中国电力建设集团(股份)有限公司(以下简称"股份公司")的全资子企业,其历史可以追溯至1950年成立的燃料工业部西南水力发电工程处。经过70多年发展壮大,已成为在能源电力、水资源与环境、城市建设与基础设施领域,为全球客户提供规划咨询、勘测设计、施工建造、投资运营全产业链一体化综合服务的大型综合性勘测设计研究单位。
  1687. 成都院致力于为全球清洁能源工程及基础设施、环境工程提供系统产品与整体解决方案和服务。公司现有1名首届国家卓越工程师、2名全国工程勘察设计大师、2名国家百千万人才专家、7名全国行业大师、15名四川省勘察设计大师在内的近7000名高素质人才队伍。');
  1688. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2016, 'is_filled', 'true');
  1689. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2016, 'fill_source', 'manual');
  1690. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2040, 'value_text', '《关于深入开展电力安全生产标准化建设暨安全环保提升专项行动的通知》(蓉设安环〔2024〕20号)');
  1691. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2040, 'is_filled', 'true');
  1692. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2040, 'fill_source', 'manual');
  1693. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2041, 'value_text', '成都院本部各职能部门、勘测设计分公司/YX工程院/抽蓄院(简称:设计分公司)、工程建设分公司(简称:建设分公司)、重庆云阳建全抽水蓄能电站EPC总承包监理项目(简称:云阳监理项目)、漳州高新区绿色发展生态治理项目工程总承包(EPC)建设项目(简称:漳州总包项目)、大邑抽水蓄能电站地质勘察项目(简称:大邑地勘项目)、大渡河双江口设计项目(简称:双江口设计项目)');
  1694. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2041, 'is_filled', 'true');
  1695. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2041, 'fill_source', 'manual');
  1696. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2043, 'value_text', '2024年10月17日上10:30~12:00');
  1697. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2043, 'is_filled', 'true');
  1698. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2043, 'fill_source', 'manual');
  1699. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2045, 'is_filled', 'true');
  1700. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2045, 'fill_source', 'manual');
  1701. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_json) VALUES (2045, 'value_json', NULL, '[{"序号": 1, "姓名": "葛学福", "职务": "专家组长", "专业": "安全管理、作业安全", "工作单位": "江西水电"}, {"序号": 2, "姓名": "余正坚", "职务": "专家", "专业": "安全管理、设备设施", "工作单位": "水电七局"}, {"序号": 3, "姓名": "苏经仪", "职务": "专家", "专业": "安全管理、作业安全", "工作单位": "昆明院"}, {"序号": 4, "姓名": "周建胜", "职务": "专家", "专业": "安全管理、设备设施", "工作单位": "安源公司"}, {"序号": 5, "姓名": "赵泓", "职务": "专家", "专业": "安全管理", "工作单位": "安源公司"}, {"序号": 6, "姓名": "朱晓莉", "职务": "项目经理", "专业": "安全管理", "工作单位": "安源公司"}, {"序号": 7, "姓名": "向义", "职务": "现场经理", "专业": "安全管理", "工作单位": "安源公司"}]'::jsonb);
  1702. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2047, 'is_filled', 'true');
  1703. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (2047, 'fill_source', 'manual');
  1704. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_json) VALUES (2047, 'value_json', NULL, '[{"序号": 1, "项目": "5.1.1.1\n目标制定", "存在的问题": "大邑地勘项目部制定的2024年度安全生产目标,缺少设备设施方面的事故控制目标。", "扣分标准": "依据评分标准②目标内容有缺失,扣1分/项,共扣1分。"}, {"序号": 2, "项目": "5.1.1.2\n目标落实", "存在的问题": "双江口设计项目部项目经理与各专业部门负责人签订的《2024年度安全责任书》中,目标分解不明确,不满足要求。", "扣分标准": "依据评分标准②签订责任书、目标分解不满足要求,扣1分/单位,共扣1分。"}, {"序号": 3, "项目": "5.1.1.3\n目标考核", "存在的问题": "云阳监理项目未对二季度安全生产目标及工作计划完成情况进行考核、监督检查。", "扣分标准": "依据评分标准①未对目标的完成情况进行评估和考核,扣2分/次,共扣2分。"}, {"序号": 4, "项目": "5.1.2.1\n机构设置", "存在的问题": "漳州总包项目部安委会组成不符合规定,未包含分包单位负责人。", "扣分标准": "依据评分标准①安委会组成不符合规定或未及时调整,扣2分/次,共扣2分"}, {"序号": 5, "项目": "5.1.2.2\n主要负责人及管理层职责", "存在的问题": "双江口设计项目部9月召开的安全生产例会中,未针对成都院隐患大排查、设计分公司安全风险隐患专项整治工作等要求,部署安排隐患排查相关工作。", "扣分标准": "依据评分标准④会议未布置安全生产工作,扣1分/项,共扣1分。"}]'::jsonb);
  1705. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (400, 'file_name', '现场检测点位布置图.pdf');
  1706. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (400, 'file_type', 'pdf');
  1707. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (400, 'file_path', '/uploads/2026/02/ATT-001.pdf');
  1708. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (400, 'parse_status', 'completed');
  1709. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (401, 'file_name', '现场检测照片.zip');
  1710. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (401, 'file_type', 'zip');
  1711. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (401, 'file_path', '/uploads/2026/02/ATT-002.zip');
  1712. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (401, 'parse_status', 'completed');
  1713. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (402, 'file_name', '检测计划与检测方案.docx');
  1714. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (402, 'file_type', 'docx');
  1715. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (402, 'file_path', '/uploads/2026/02/ATT-003.docx');
  1716. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (402, 'parse_status', 'completed');
  1717. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (403, 'file_name', '工况记录表.xlsx');
  1718. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (403, 'file_type', 'xlsx');
  1719. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (403, 'file_path', '/uploads/2026/02/ATT-004.xlsx');
  1720. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (403, 'parse_status', 'completed');
  1721. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (404, 'file_name', '噪声检测原始记录表.xlsx');
  1722. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (404, 'file_type', 'xlsx');
  1723. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (404, 'file_path', '/uploads/2026/02/ATT-005.xlsx');
  1724. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (404, 'parse_status', 'completed');
  1725. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (405, 'file_name', '工频电场、工频磁场检测原始记录表.xlsx');
  1726. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (405, 'file_type', 'xlsx');
  1727. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (405, 'file_path', '/uploads/2026/02/ATT-006.xlsx');
  1728. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (405, 'parse_status', 'completed');
  1729. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (500, 'entity_type', 'organization');
  1730. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (500, 'business_label', '评审对象');
  1731. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_number) VALUES (500, 'confidence', NULL, 0.99);
  1732. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (501, 'entity_type', 'organization');
  1733. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (501, 'business_label', '上级公司');
  1734. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_number) VALUES (501, 'confidence', NULL, 0.98);
  1735. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (502, 'entity_type', 'organization');
  1736. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (502, 'business_label', '评审机构');
  1737. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_number) VALUES (502, 'confidence', NULL, 0.99);
  1738. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (503, 'entity_type', 'alias');
  1739. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (503, 'business_label', '评审对象简称');
  1740. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_number) VALUES (503, 'confidence', NULL, 0.99);
  1741. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (504, 'entity_type', 'code');
  1742. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (504, 'business_label', '项目编号');
  1743. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_number) VALUES (504, 'confidence', NULL, 0.99);
  1744. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (505, 'entity_type', 'code');
  1745. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (505, 'business_label', '证书编号');
  1746. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_number) VALUES (505, 'confidence', NULL, 0.98);
  1747. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (506, 'entity_type', 'person');
  1748. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (506, 'business_label', '董事长');
  1749. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_number) VALUES (506, 'confidence', NULL, 0.97);
  1750. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (507, 'entity_type', 'person');
  1751. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (507, 'business_label', '总经理');
  1752. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_number) VALUES (507, 'confidence', NULL, 0.96);
  1753. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (508, 'entity_type', 'person');
  1754. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (508, 'business_label', '分管安全副总经理');
  1755. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_number) VALUES (508, 'confidence', NULL, 0.96);
  1756. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (509, 'entity_type', 'person');
  1757. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (509, 'business_label', '安全总监');
  1758. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_number) VALUES (509, 'confidence', NULL, 0.95);
  1759. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (510, 'entity_type', 'person');
  1760. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (510, 'business_label', '安质环部主任');
  1761. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_number) VALUES (510, 'confidence', NULL, 0.95);
  1762. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (511, 'entity_type', 'number');
  1763. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (511, 'business_label', '评审得分');
  1764. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_number) VALUES (511, 'confidence', NULL, 0.99);
  1765. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (512, 'entity_type', 'level');
  1766. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (512, 'business_label', '评审级别');
  1767. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_number) VALUES (512, 'confidence', NULL, 0.99);
  1768. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (513, 'entity_type', 'date');
  1769. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (513, 'business_label', '评审开始日期');
  1770. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_number) VALUES (513, 'confidence', NULL, 0.98);
  1771. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (514, 'entity_type', 'date');
  1772. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (514, 'business_label', '评审结束日期');
  1773. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_number) VALUES (514, 'confidence', NULL, 0.98);
  1774. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (600, 'rule_type', 'extraction');
  1775. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (600, 'action_type', 'extract_pattern');
  1776. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_json) VALUES (600, 'action_config', NULL, '{"pattern": "项目编号[::]\\s*(\\S+)", "group": 1}'::jsonb);
  1777. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (600, 'dsl_content', 'EXTRACT pattern="项目编号[::]\s*(\S+)" FROM input1');
  1778. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (600, 'last_output_text', 'BZ-0092-2024');
  1779. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (600, 'last_run_status', 'success');
  1780. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (601, 'rule_type', 'direct_entity');
  1781. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (601, 'action_type', 'use_entity_value');
  1782. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (601, 'description', '直接使用附件实体值填充评审对象');
  1783. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (601, 'last_output_text', '中国电建集团成都勘测设计研究院有限公司');
  1784. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (601, 'last_run_status', 'success');
  1785. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (602, 'rule_type', 'extraction');
  1786. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (602, 'action_type', 'extract_pattern');
  1787. INSERT INTO node_properties (node_id, prop_key, prop_value, prop_json) VALUES (602, 'action_config', NULL, '{"pattern": "评审得分[::]\\s*([\\d.]+)", "group": 1}'::jsonb);
  1788. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (602, 'dsl_content', 'EXTRACT pattern="评审得分[::]\s*([\d.]+)" FROM input1');
  1789. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (602, 'last_output_text', '93.33');
  1790. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (602, 'last_run_status', 'success');
  1791. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (603, 'rule_type', 'direct_entity');
  1792. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (603, 'action_type', 'use_entity_value');
  1793. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (603, 'description', '直接使用实体值填充评审对象简称');
  1794. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (603, 'last_output_text', '成都院');
  1795. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (603, 'last_run_status', 'success');
  1796. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (604, 'rule_type', 'direct_entity');
  1797. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (604, 'action_type', 'use_entity_value');
  1798. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (604, 'description', '直接使用实体值填充申请级别');
  1799. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (604, 'last_output_text', '一级');
  1800. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (604, 'last_run_status', 'success');
  1801. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (300, 'report_code', 'RPT-SPSRR-HDY-2024');
  1802. INSERT INTO node_properties (node_id, prop_key, prop_value) VALUES (300, 'title', '华东院2024年安全生产标准化复审报告');
  1803. -- ============================================================
  1804. -- 8. Mock数据 - edge_properties
  1805. -- ============================================================
  1806. INSERT INTO edge_properties (edge_id, prop_key, prop_value) VALUES (620, 'input_key', 'input1');
  1807. INSERT INTO edge_properties (edge_id, prop_key, prop_value) VALUES (620, 'input_type', 'source_file_ref');
  1808. INSERT INTO edge_properties (edge_id, prop_key, prop_value) VALUES (621, 'input_key', 'entity');
  1809. INSERT INTO edge_properties (edge_id, prop_key, prop_value) VALUES (621, 'input_type', 'entity_ref');
  1810. INSERT INTO edge_properties (edge_id, prop_key, prop_value) VALUES (622, 'input_key', 'input1');
  1811. INSERT INTO edge_properties (edge_id, prop_key, prop_value) VALUES (622, 'input_type', 'source_file_ref');
  1812. INSERT INTO edge_properties (edge_id, prop_key, prop_value) VALUES (623, 'input_key', 'entity');
  1813. INSERT INTO edge_properties (edge_id, prop_key, prop_value) VALUES (623, 'input_type', 'entity_ref');
  1814. INSERT INTO edge_properties (edge_id, prop_key, prop_value) VALUES (624, 'input_key', 'entity');
  1815. INSERT INTO edge_properties (edge_id, prop_key, prop_value) VALUES (624, 'input_type', 'entity_ref');
  1816. -- ============================================================
  1817. -- 完成
  1818. -- ============================================================
  1819. COMMIT;
  1820. -- 验证数据
  1821. -- SELECT node_type, COUNT(*) FROM nodes GROUP BY node_type ORDER BY node_type;
  1822. -- SELECT edge_type, COUNT(*) FROM edges GROUP BY edge_type ORDER BY edge_type;
  1823. -- SELECT * FROM v_reports;
  1824. -- SELECT * FROM v_template_elements WHERE template_id = 101 ORDER BY sort_order;
  1825. -- SELECT * FROM v_report_element_values WHERE report_id = 200;