ems_server.sql 158 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010
  1. SET NAMES utf8mb4;
  2. -- ----------------------------
  3. -- 能源分类
  4. -- ----------------------------
  5. drop table if exists dim_gb_ems_cls;
  6. create table dim_gb_ems_cls (
  7. `id` bigint(20) not null auto_increment comment '序号',
  8. `code` varchar(16) not null comment '能源代码',
  9. `name` varchar(32) not null comment '能源种类',
  10. `desc` varchar(256) default null comment '说明',
  11. `level` int(4) default 0 comment '分类层级 1-大类,2-中类,3-小类',
  12. `parent_code` varchar(16) default null comment '父类代码',
  13. `version` varchar(64) default null comment '数据版本',
  14. primary key (`id`),
  15. unique key ux_ems_cls_code(`code`)
  16. ) engine=innodb auto_increment=1 comment = '能源分类';
  17. -- 能源分类初始数据
  18. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('10', '煤炭及煤制品', null, 1, '-1', 'GB/T 29870-2013');
  19. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('1001', '无烟煤', null, 2, '10', 'GB/T 29870-2013');
  20. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('1002', '烟煤', null, 2, '10', 'GB/T 29870-2013');
  21. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100201', '贫煤', null, 3, '1002', 'GB/T 29870-2013');
  22. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100202', '贫瘦煤', null, 3, '1002', 'GB/T 29870-2013');
  23. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100203', '瘦煤', null, 3, '1002', 'GB/T 29870-2013');
  24. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100204', '焦煤', null, 3, '1002', 'GB/T 29870-2013');
  25. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100205', '肥煤', null, 3, '1002', 'GB/T 29870-2013');
  26. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100206', '1/3焦煤', null, 3, '1002', 'GB/T 29870-2013');
  27. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100207', '气肥煤', null, 3, '1002', 'GB/T 29870-2013');
  28. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100208', '气煤', null, 3, '1002', 'GB/T 29870-2013');
  29. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100209', '1/2中黏煤', null, 3, '1002', 'GB/T 29870-2013');
  30. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100210', '弱黏煤', null, 3, '1002', 'GB/T 29870-2013');
  31. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100211', '不黏煤', null, 3, '1002', 'GB/T 29870-2013');
  32. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100212', '长焰煤', null, 3, '1002', 'GB/T 29870-2013');
  33. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100299', '其他烟煤', null, 3, '1002', 'GB/T 29870-2013');
  34. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('1003', '褐煤', null, 2, '10', 'GB/T 29870-2013');
  35. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('1004', '煤制品', '指除煤制油以外的煤炭制品', 2, '10', 'GB/T 29870-2013');
  36. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100401', '焦炭', '包括焦炉焦炭、煤气焦炭、焦炭渣和半焦炭等0', 3, '1004', 'GB/T 29870-2013');
  37. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100402', '型煤', '包括煤球、煤砖、蜂窝煤等', 3, '1004', 'GB/T 29870-2013');
  38. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100403', '煤制二甲醚', null, 3, '1004', 'GB/T 29870-2013');
  39. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100404', '炼焦油', null, 3, '1004', 'GB/T 29870-2013');
  40. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100405', '焦炉气', null, 3, '1004', 'GB/T 29870-2013');
  41. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100406', '炼厂煤气', null, 3, '1004', 'GB/T 29870-2013');
  42. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100407', '再利用煤气', '包括高炉煤气、氧化煤气等', 3, '1004', 'GB/T 29870-2013');
  43. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100408', '煤制天然气', null, 3, '1004', 'GB/T 29870-2013');
  44. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100499', '其他煤制品', null, 3, '1004', 'GB/T 29870-2013');
  45. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('1005', '煤制油', null, 2, '10', 'GB/T 29870-2013');
  46. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100501', '煤制石脑油', null, 3, '1005', 'GB/T 29870-2013');
  47. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100502', '煤制汽油', null, 3, '1005', 'GB/T 29870-2013');
  48. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100503', '煤制柴油', null, 3, '1005', 'GB/T 29870-2013');
  49. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100504', '煤制航空燃料', null, 3, '1005', 'GB/T 29870-2013');
  50. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100505', '煤制石蜡', null, 3, '1005', 'GB/T 29870-2013');
  51. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('100599', '其他煤制油', null, 3, '1005', 'GB/T 29870-2013');
  52. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('1099', '其他煤炭及煤制品', null, 2, '1005', 'GB/T 29870-2013');
  53. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('15', '泥炭及泥炭产物', '又名“泥煤”、“草煤”、“草碳”,包括泥碳片、碾碎泥炭、泥炭产物等', 1, '-1', 'GB/T 29870-2013');
  54. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('20', '油页岩/油沙', null, 1, '-1', 'GB/T 29870-2013');
  55. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('2001', '页岩气', '指主体以上吸附或游离状态存在于泥岩、高碳泥岩、页岩及粉砂质岩类夹层中的天然气', 2, '20', 'GB/T 29870-2013');
  56. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('2099', '其他油页岩/油砂', null, 2, '20', 'GB/T 29870-2013');
  57. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('25', '天然气', null, 1, '-1', 'GB/T 29870-2013');
  58. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('2501', '常规天然气', '指由常规油器藏开发出的天然气', 2, '25', 'GB/T 29870-2013');
  59. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('250101', '纯气田天然气', '指气藏中以气相存的天然气,通过气井开采出来的非伴生气', 3, '2501', 'GB/T 29870-2013');
  60. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('250102', '凝析气田天然气', '指天然气从地层流出井口后,随着压力和温度的下降,分离生成的气相伴生气', 3, '2501', 'GB/T 29870-2013');
  61. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('250103', '伴生天然气', '指与石油伴生的天然气', 3, '2501', 'GB/T 29870-2013');
  62. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('250199', '其他常规天然气', null, 3, '2501', 'GB/T 29870-2013');
  63. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('2502', '非常规天然气', '指难于用传统油气生成理论解释,在地下的赋存状态和聚集方式与常规天然气藏具有明显差异的天然气聚集', 2, '25', 'GB/T 29870-2013');
  64. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('250201', '煤成气', '指含煤岩层中有机质在成煤过程中所生成的天然气', 3, '2502', 'GB/T 29870-2013');
  65. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('250202', '煤层气', '又名“煤层甲烷”、“瓦斯”,指赋存在煤层中以甲烷为主要成分、以吸附在煤基质颗粒表面为主、部分游离于煤孔隙中或溶解于煤层水中的烃类气体', 3, '2502', 'GB/T 29870-2013');
  66. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('250203', '深层气', '指深埋层位生成与储集的天然气,即地球沉积层深部层位形成或赋存的天然气', 3, '2502', 'GB/T 29870-2013');
  67. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('250204', '天然气水合物', '又名“可燃冰”', 3, '2502', 'GB/T 29870-2013');
  68. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('250299', '其他非常规天然气', null, 3, '2502', 'GB/T 29870-2013');
  69. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('2503', '天然气加工制品', null, 2, '25', 'GB/T 29870-2013');
  70. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('250301', '液化天然气', null, 3, '2503', 'GB/T 29870-2013');
  71. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('250302', '压缩天然气', null, 3, '2503', 'GB/T 29870-2013');
  72. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('250399', '其他天然气加工制品', null, 3, '2503', 'GB/T 29870-2013');
  73. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('2599', '其他天然气', null, 2, '25', 'GB/T 29870-2013');
  74. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('30', '石油及石油制品', null, 1, '-1', 'GB/T 29870-2013');
  75. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('3001', '原油', null, 2, '30', 'GB/T 29870-2013');
  76. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('3002', '天然气凝析液', null, 2, '30', 'GB/T 29870-2013');
  77. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('3003', '石油制品', null, 2, '30', 'GB/T 29870-2013');
  78. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('300301', '汽油', '包括航空汽油和车用汽油', 3, '3003', 'GB/T 29870-2013');
  79. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('300302', '煤油', '包括航空煤油和灯用煤油等', 3, '3003', 'GB/T 29870-2013');
  80. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('300303', '柴油', null, 3, '3003', 'GB/T 29870-2013');
  81. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('300304', '燃料油', '包括船用燃料和工业用燃料油等', 3, '3003', 'GB/T 29870-2013');
  82. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('300305', '燃料气', '包括野花石油气、炼厂干气和甲烷氢等', 3, '3003', 'GB/T 29870-2013');
  83. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('300306', '石蜡', null, 3, '3003', 'GB/T 29870-2013');
  84. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('300307', '沥青', '包括煤焦沥青和石油沥青等', 3, '3003', 'GB/T 29870-2013');
  85. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('300308', '石焦油', null, 3, '3003', 'GB/T 29870-2013');
  86. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('300399', '其他石油制品', null, 3, '3003', 'GB/T 29870-2013');
  87. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('3099', '其他石油及石油制品', null, 2, '30', 'GB/T 29870-2013');
  88. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('35', '生物质能', null, 1, '-1', 'GB/T 29870-2013');
  89. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('3501', '固态生物燃料', null, 2, '35', 'GB/T 29870-2013');
  90. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('350101', '薪材、木材残渣和副产品', '包括树皮、薪柴、锯末刨花等', 3, '3501', 'GB/T 29870-2013');
  91. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('350102', '动物肥料', null, 3, '3501', 'GB/T 29870-2013');
  92. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('350103', '植物材料和剩余物', '包括玉米棒、稻壳、木索、麻等', 3, '3501', 'GB/T 29870-2013');
  93. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('350104', '木炭', null, 3, '3501', 'GB/T 29870-2013');
  94. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('350199', '其他固态生物燃料', null, 3, '3501', 'GB/T 29870-2013');
  95. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('3502', '液态生物燃料', null, 2, '35', 'GB/T 29870-2013');
  96. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('350201', '生物汽油', null, 3, '3502', 'GB/T 29870-2013');
  97. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('350202', '生物柴油', null, 3, '3502', 'GB/T 29870-2013');
  98. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('350203', '生物航空煤油', null, 3, '3502', 'GB/T 29870-2013');
  99. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('350299', '其他液体生物燃料', null, 3, '3502', 'GB/T 29870-2013');
  100. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('3503', '生物气', null, 2, '35', 'GB/T 29870-2013');
  101. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('350301', '沼气', null, 3, '3503', 'GB/T 29870-2013');
  102. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('350302', '热处理过程中生物气', null, 3, '3503', 'GB/T 29870-2013');
  103. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('350303', '其他生物气', null, 3, '3503', 'GB/T 29870-2013');
  104. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('3599', '其他生物质能', null, 2, '35', 'GB/T 29870-2013');
  105. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('40', '废料能', null, 1, '-1', 'GB/T 29870-2013');
  106. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('45', '电能', null, 1, '-1', 'GB/T 29870-2013');
  107. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('4501', '火力发电', '指利用煤、石油、天然气等固体、液体、气体燃料燃烧时产生的热能,通过发电动力装置转换成电能的一种发电方式', 2, '45', 'GB/T 29870-2013');
  108. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450101', '燃煤发电', null, 3, '4501', 'GB/T 29870-2013');
  109. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450102', '燃油发电', null, 3, '4501', 'GB/T 29870-2013');
  110. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450103', '燃气发电', null, 3, '4501', 'GB/T 29870-2013');
  111. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450199', '其他火力发电', null, 3, '4501', 'GB/T 29870-2013');
  112. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('4502', '水力发电', '指将河流、湖泊或海洋等水体所蕴藏的水能转变为电能的发电方式', 2, '45', 'GB/T 29870-2013');
  113. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450201', '大型水电站发电', '指装机容量在300000kw以上的水电站', 3, '4502', 'GB/T 29870-2013');
  114. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450202', '中型水电站发电', '指装机容量在50000kw-300000kw的水电站', 3, '4502', 'GB/T 29870-2013');
  115. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450203', '抽水蓄能', null, 3, '4502', 'GB/T 29870-2013');
  116. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450299', '其他水力发电', null, 3, '4502', 'GB/T 29870-2013');
  117. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('4503', '核能发电', null, 2, '45', 'GB/T 29870-2013');
  118. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450301', '大、中型商用核电', '指用于电网基荷电源的核电', 3, '4503', 'GB/T 29870-2013');
  119. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450302', '小型模块式核电', '指用于偏远地区、岛屿及专用用户供电的核电', 3, '4503', 'GB/T 29870-2013');
  120. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450303', '电热联供核电', null, 3, '4503', 'GB/T 29870-2013');
  121. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450304', '空间核反应堆电源', '指航天器与空间站专用电源', 3, '4503', 'GB/T 29870-2013');
  122. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450305', '同位素电池', null, 3, '4503', 'GB/T 29870-2013');
  123. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450399', '其他核能发电', null, 3, '4503', 'GB/T 29870-2013');
  124. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('4504', '可再生能源发电', null, 2, '45', 'GB/T 29870-2013');
  125. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450401', '风力发电', null, 3, '4504', 'GB/T 29870-2013');
  126. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450402', '太阳能发电', '包括太阳能光伏发电、太阳能热发电等', 3, '4504', 'GB/T 29870-2013');
  127. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450403', '小型水电站发电', '指装机容量在50000kw以下的小水电站', 3, '4504', 'GB/T 29870-2013');
  128. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450404', '生物质能发电', null, 3, '4504', 'GB/T 29870-2013');
  129. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450405', '地热能发电', null, 3, '4504', 'GB/T 29870-2013');
  130. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450406', '海洋能发电', '包括海洋温差能发电、潮汐能发电和波浪能发电等', 3, '4504', 'GB/T 29870-2013');
  131. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('450499', '其他可再生能源发电', null, 3, '4504', 'GB/T 29870-2013');
  132. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('4505', '垃圾发电', '指通过特殊的焚烧锅炉和燃烧城市固体垃圾,再通过蒸汽轮机发电机组发电', 2, '45', 'GB/T 29870-2013');
  133. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('4506', '余热余压发电', '指利用企业生产过程中释放出来多余的副产热能、压差能来发电', 2, '45', 'GB/T 29870-2013');
  134. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('4599', '其他电能', null, 2, '45', 'GB/T 29870-2013');
  135. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('50', '热能', null, 1, '-1', 'GB/T 29870-2013');
  136. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('5001', '太阳能供热', null, 2, '50', 'GB/T 29870-2013');
  137. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('5002', '生物质能供热', '包括秸秆、薪柴、粪便燃烧取热等', 2, '50', 'GB/T 29870-2013');
  138. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('5003', '地热能产热', null, 2, '50', 'GB/T 29870-2013');
  139. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('5004', '化石燃烧供热', null, 2, '50', 'GB/T 29870-2013');
  140. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('5005', '核能直接供热', null, 2, '50', 'GB/T 29870-2013');
  141. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('500501', '高温核供热', '指供热温度高于550℃的冶金、化工工艺', 3, '5005', 'GB/T 29870-2013');
  142. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('500502', '低温核供热', null, 3, '5005', 'GB/T 29870-2013');
  143. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('500503', '热电联供核电厂供热', null, 3, '5005', 'GB/T 29870-2013');
  144. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('500599', '其他核能直接供热', null, 3, '5005', 'GB/T 29870-2013');
  145. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('5006', '废料燃烧供热', null, 2, '50', 'GB/T 29870-2013');
  146. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('5007', '电热锅炉供热', null, 2, '50', 'GB/T 29870-2013');
  147. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('5008', '热泵供热', '包括地源、空气源荷水源热泵产热', 2, '50', 'GB/T 29870-2013');
  148. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('5009', '余热余压供热', null, 2, '50', 'GB/T 29870-2013');
  149. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('55', '核能', null, 1, '-1', 'GB/T 29870-2013');
  150. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('5501', '天然铀矿藏', null, 2, '55', 'GB/T 29870-2013');
  151. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550101', '砂岩型矿石', null, 3, '5501', 'GB/T 29870-2013');
  152. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550102', '碳硅泥岩型矿石', null, 3, '5501', 'GB/T 29870-2013');
  153. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550103', '花岗岩型矿石', null, 3, '5501', 'GB/T 29870-2013');
  154. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550104', '火山岩型矿石', null, 3, '5501', 'GB/T 29870-2013');
  155. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550105', '岩浆岩型矿石', null, 3, '5501', 'GB/T 29870-2013');
  156. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550199', '其他天然铀矿藏', null, 3, '5501', 'GB/T 29870-2013');
  157. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('5502', '钍矿藏', null, 2, '55', 'GB/T 29870-2013');
  158. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('5503', '铀矿生产的中间产品', '指从天然铀到核燃料生产过程中可供销售的产品', 2, '55', 'GB/T 29870-2013');
  159. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550301', '黄饼', null, 3, '5503', 'GB/T 29870-2013');
  160. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550302', '四氟化铀', null, 3, '5503', 'GB/T 29870-2013');
  161. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550303', '六氟化铀', null, 3, '5503', 'GB/T 29870-2013');
  162. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550304', '铀金属及铀合金', null, 3, '5503', 'GB/T 29870-2013');
  163. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550305', '低富集铀', '指铀-235富集度<20%的富集铀产品', 3, '5503', 'GB/T 29870-2013');
  164. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550306', '高富集铀', '指铀-235富集度>=20%富集铀产品', 3, '5503', 'GB/T 29870-2013');
  165. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550307', '二氧化铀', null, 3, '5503', 'GB/T 29870-2013');
  166. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550308', '钚', null, 3, '5503', 'GB/T 29870-2013');
  167. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550309', '回收铀', null, 3, '5503', 'GB/T 29870-2013');
  168. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550310', '铀钚混合氧化物', null, 3, '5503', 'GB/T 29870-2013');
  169. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550311', '贫铀', null, 3, '5503', 'GB/T 29870-2013');
  170. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550312', '铀钍混合氧化物', null, 3, '5503', 'GB/T 29870-2013');
  171. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550313', '碳铀化物及氮铀化物', null, 3, '5503', 'GB/T 29870-2013');
  172. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550399', '其他铀生产的中间产品', null, 3, '5503', 'GB/T 29870-2013');
  173. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('5504', '核聚变反应材料或其原材料', null, 2, '55', 'GB/T 29870-2013');
  174. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550401', '氘', null, 3, '5504', 'GB/T 29870-2013');
  175. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550402', '氚', null, 3, '5504', 'GB/T 29870-2013');
  176. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550403', '锂', null, 3, '5504', 'GB/T 29870-2013');
  177. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('550499', '其他核聚变反应材料或其原材料', null, 3, '5504', 'GB/T 29870-2013');
  178. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('5599', '其他核能', null, 2, '55', 'GB/T 29870-2013');
  179. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('60', '氢能', null, 1, '-1', 'GB/T 29870-2013');
  180. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('99', '其他', null, 1, '-1', 'GB/T 29870-2013');
  181. INSERT INTO `dim_gb_ems_cls` (`code`, `name`, `desc`, `level`, `parent_code`, `version`) VALUES ('70', '自来水', NULL, 1, '-1', NULL);
  182. -- ----------------------------
  183. -- 能源设施分类
  184. -- ----------------------------
  185. drop table if exists dim_ems_facs_category;
  186. create table dim_ems_facs_category (
  187. `id` bigint(20) not null auto_increment comment '序号',
  188. `code` varchar(8) not null comment '设施系统代码',
  189. `name` varchar(16) not null comment '设施系统名称',
  190. `desc` varchar(64) default null comment '说明',
  191. `version` varchar(64) default null comment '数据版本',
  192. primary key (`id`),
  193. unique key ux_ems_facs_category_code(`code`)
  194. ) engine=innodb auto_increment=1 comment = '能源设施分类';
  195. -- 能源设施初始数据
  196. INSERT INTO `dim_ems_facs_category` (`code`, `name`, `desc`, `version`) VALUES ('E', '能源生产系统', '全站码', 'GB/T 43033-2013');
  197. INSERT INTO `dim_ems_facs_category` (`code`, `name`, `desc`, `version`) VALUES ('T', '中转系统', '全站码', 'GB/T 43033-2013');
  198. INSERT INTO `dim_ems_facs_category` (`code`, `name`, `desc`, `version`) VALUES ('W', '传输系统', '区位码', 'GB/T 43033-2013');
  199. INSERT INTO `dim_ems_facs_category` (`code`, `name`, `desc`, `version`) VALUES ('C', '存储系统', '全站码', 'GB/T 43033-2013');
  200. INSERT INTO `dim_ems_facs_category` (`code`, `name`, `desc`, `version`) VALUES ('Z', '用能系统', '区位码', 'GB/T 43033-2013');
  201. -- ----------------------------
  202. -- 能源设施子类
  203. -- ----------------------------
  204. drop table if exists dim_ems_facs_subcategory;
  205. create table dim_ems_facs_subcategory (
  206. `id` bigint(20) not null auto_increment comment '序号',
  207. `code` varchar(8) not null comment '设施子类代码',
  208. `name` varchar(16) not null comment '设施子类名称',
  209. `parent_code` varchar(8) not null comment '所属设施系统分类代码',
  210. `desc` varchar(64) default null comment '说明',
  211. `version` varchar(64) default null comment '数据版本',
  212. primary key (`id`),
  213. unique key ux_ems_facs_subcategory_code(`code`)
  214. ) engine=innodb auto_increment=1 comment = '能源设施子类';
  215. -- 能源设施初始数据
  216. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('E1', '天然气分布式供能站', 'E', null, 'GB/T 43033-2013');
  217. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('E2', '生物质发电站', 'E', null, 'GB/T 43033-2013');
  218. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('E3', '分布式风力发电场', 'E', null, 'GB/T 43033-2013');
  219. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('E4', '小型水力发电站', 'E', null, 'GB/T 43033-2013');
  220. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('E5', '分布式光伏发电系统', 'E', null, 'GB/T 43033-2013');
  221. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('E6', '太阳能供热站', 'E', null, 'GB/T 43033-2013');
  222. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('E7', '锅炉供热站(电、燃气等型式)', 'E', null, 'GB/T 43033-2013');
  223. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('T1', '换热站', 'T', null, 'GB/T 43033-2013');
  224. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('T2', '制冷/热站', 'T', null, 'GB/T 43033-2013');
  225. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('T3', '热泵站', 'T', null, 'GB/T 43033-2013');
  226. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('T4', '供氢站', 'T', null, 'GB/T 43033-2013');
  227. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('W1', '管网', 'W', null, 'GB/T 43033-2013');
  228. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('W2', '配电网', 'W', null, 'GB/T 43033-2013');
  229. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('W3', '中继泵站', 'W', null, 'GB/T 43033-2013');
  230. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('W4', '能耗监测', 'W', null, 'GB/T 43033-2013');
  231. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('C1', '电化学储能站', 'C', null, 'GB/T 43033-2013');
  232. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('C2', '飞轮、压缩空气等机械储能站', 'C', null, 'GB/T 43033-2013');
  233. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('C3', '蓄冷/热站', 'C', null, 'GB/T 43033-2013');
  234. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('C4', '储氢站', 'C', null, 'GB/T 43033-2013');
  235. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('Z010', '照明设施', 'Z', null, null);
  236. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('Z020', '暖通设施', 'Z', null, null);
  237. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('Z030', '安防设施', 'Z', null, null);
  238. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('Z040', '服务设施', 'Z', null, null);
  239. INSERT INTO `dim_ems_facs_subcategory` (`code`, `name`, `parent_code`, `desc`, `version`) VALUES ('Z999', '其他设施', 'Z', null, null);
  240. -- ----------------------------
  241. -- 能源设备工艺标识维表
  242. -- ----------------------------
  243. drop table if exists dim_ems_dev_process;
  244. create table dim_ems_dev_process (
  245. `id` bigint(20) not null auto_increment comment '序号',
  246. `ps_code` varchar(16) not null comment '工艺代码',
  247. `ps_name` varchar(64) not null comment '工艺名称',
  248. `desc` varchar(128) default null comment '工艺系统说明',
  249. `category_code` varchar(8) default null comment '设施分类代码',
  250. `subcategory_code` varchar(8) default null comment '设施子类代码',
  251. `version` varchar(64) default null comment '数据版本',
  252. primary key (`id`),
  253. unique key ux_ems_facs_facs_process(`ps_code`)
  254. ) engine=innodb auto_increment=1 comment = '能源设施工艺系统维表';
  255. -- 能源设备工艺标识维表初始数据
  256. INSERT INTO `dim_ems_dev_process` (`ps_code`, `ps_name`, `desc`, `category_code`, `subcategory_code`, `version`) VALUES ('T', '变压器', null, 'W', 'W2', null);
  257. INSERT INTO `dim_ems_dev_process` (`ps_code`, `ps_name`, `desc`, `category_code`, `subcategory_code`, `version`) VALUES ('AA', '高压配电柜', null, 'W', 'W2', null);
  258. INSERT INTO `dim_ems_dev_process` (`ps_code`, `ps_name`, `desc`, `category_code`, `subcategory_code`, `version`) VALUES ('AH', '高压开关柜', null, 'W', 'W2', null);
  259. INSERT INTO `dim_ems_dev_process` (`ps_code`, `ps_name`, `desc`, `category_code`, `subcategory_code`, `version`) VALUES ('AJ', '高压电容柜', null, 'W', 'W2', null);
  260. INSERT INTO `dim_ems_dev_process` (`ps_code`, `ps_name`, `desc`, `category_code`, `subcategory_code`, `version`) VALUES ('AM', '高压计量柜', null, 'W', 'W2', null);
  261. INSERT INTO `dim_ems_dev_process` (`ps_code`, `ps_name`, `desc`, `category_code`, `subcategory_code`, `version`) VALUES ('AP', '低压配电柜', null, 'W', 'W2', null);
  262. INSERT INTO `dim_ems_dev_process` (`ps_code`, `ps_name`, `desc`, `category_code`, `subcategory_code`, `version`) VALUES ('AL', '低压照明配电柜', null, 'W', 'W2', null);
  263. INSERT INTO `dim_ems_dev_process` (`ps_code`, `ps_name`, `desc`, `category_code`, `subcategory_code`, `version`) VALUES ('APE', '应急电力配电柜', null, 'W', 'W2', null);
  264. INSERT INTO `dim_ems_dev_process` (`ps_code`, `ps_name`, `desc`, `category_code`, `subcategory_code`, `version`) VALUES ('ALE', '应急照明配电柜', null, 'W', 'W2', null);
  265. INSERT INTO `dim_ems_dev_process` (`ps_code`, `ps_name`, `desc`, `category_code`, `subcategory_code`, `version`) VALUES ('AF', '低压负荷开关柜', null, 'W', 'W2', null);
  266. INSERT INTO `dim_ems_dev_process` (`ps_code`, `ps_name`, `desc`, `category_code`, `subcategory_code`, `version`) VALUES ('ACC', '低压电容补偿柜', null, 'W', 'W2', null);
  267. INSERT INTO `dim_ems_dev_process` (`ps_code`, `ps_name`, `desc`, `category_code`, `subcategory_code`, `version`) VALUES ('SM', '智能表', '智能表', 'W', 'W2', null);
  268. INSERT INTO `dim_ems_dev_process` (`ps_code`, `ps_name`, `desc`, `category_code`, `subcategory_code`, `version`) VALUES ('QF', '断路器', '空开', 'W', 'W2', null);
  269. INSERT INTO `dim_ems_dev_process` (`ps_code`, `ps_name`, `desc`, `category_code`, `subcategory_code`, `version`) VALUES ('QR', '漏电保护器', null, 'W', 'W2', null);
  270. INSERT INTO `dim_ems_dev_process` (`ps_code`, `ps_name`, `desc`, `category_code`, `subcategory_code`, `version`) VALUES ('QS', '隔离开关', null, 'W', 'W2', null);
  271. INSERT INTO `dim_ems_dev_process` (`ps_code`, `ps_name`, `desc`, `category_code`, `subcategory_code`, `version`) VALUES ('AC-EVSE', '交流充电桩', null, 'Z', 'Z040', null);
  272. INSERT INTO `dim_ems_dev_process` (`ps_code`, `ps_name`, `desc`, `category_code`, `subcategory_code`, `version`) VALUES ('DC-EVSE', '直流充电桩', null, 'Z', 'Z040', null);
  273. -- ----------------------------
  274. -- 标签分类
  275. -- ----------------------------
  276. drop table if exists dim_ems_tag;
  277. create table dim_ems_tag (
  278. `id` bigint(20) not null auto_increment comment '序号',
  279. `tag_model` varchar(128) not null comment '标签模型',
  280. `tag_code` varchar(64) not null comment '标签代码',
  281. `tag_name` varchar(128) not null comment '标签名称',
  282. `mod_flag` int not null comment '修改标记',
  283. `tag_color` varchar(64) default null comment '标签颜色',
  284. primary key (`id`),
  285. unique key ux_ems_tag(`tag_code`)
  286. ) engine=innodb auto_increment=1 comment = '标签分类';
  287. INSERT INTO dim_ems_tag (`tag_model`, `tag_code`, `tag_name`, `mod_flag`, `tag_color`) VALUES ('Area', 'Area_01', '商户区域', 0, 'rgba(255, 120, 0, 1)');
  288. INSERT INTO dim_ems_tag (`tag_model`, `tag_code`, `tag_name`, `mod_flag`, `tag_color`) VALUES ('MeterDev', 'MeterDev_Gt_45', '公摊电表', 0, 'rgba(255, 120, 0, 1)');
  289. INSERT INTO dim_ems_tag (`tag_model`, `tag_code`, `tag_name`, `mod_flag`, `tag_color`) VALUES ('MeterDev', 'MeterDev_Gt_70', '公摊水表', 0, 'rgba(255, 120, 0, 1)');
  290. -- ----------------------------
  291. -- 电价计量分类
  292. -- ----------------------------
  293. drop table if exists dim_ems_elecprice_type;
  294. create table dim_ems_elecprice_type (
  295. `id` bigint(20) not null auto_increment comment '序号',
  296. `code` int not null comment '分类类型',
  297. `name` varchar(16) not null comment '分类名称',
  298. primary key (`id`),
  299. unique key ux_elecprice_type_code(`code`)
  300. ) engine=innodb auto_increment=1 comment = '电价计量分类';
  301. INSERT INTO `dim_ems_elecprice_type` (`code`, `name`) VALUES ('1', '居民生活用电');
  302. INSERT INTO `dim_ems_elecprice_type` (`code`, `name`) VALUES ('2', '农业用电');
  303. INSERT INTO `dim_ems_elecprice_type` (`code`, `name`) VALUES ('3', '单一制');
  304. INSERT INTO `dim_ems_elecprice_type` (`code`, `name`) VALUES ('4', '两部制');
  305. -- ----------------------------
  306. -- 能源折标准煤维表
  307. -- ----------------------------
  308. drop table if exists dim_ems_discount_scoal;
  309. create table dim_ems_discount_scoal (
  310. `id` bigint(20) not null auto_increment comment '序号',
  311. `energy_code` varchar(8) not null comment '能源代码',
  312. `energy_name` varchar(16) default null comment '能源名称',
  313. `coefficient_value` double default null comment '系数值',
  314. `coefficient_unit` varchar(16) default null comment '系数单位',
  315. primary key (`id`),
  316. unique key ux_ems_discount_scoal(`energy_code`)
  317. ) engine=innodb auto_increment=1 comment = '能源折标准煤维表';
  318. INSERT INTO `dim_ems_discount_scoal` (`energy_code`, `energy_name`, `coefficient_value`, `coefficient_unit`) VALUES ('10', '原煤', 0.7143, 'kgce/kg');
  319. INSERT INTO `dim_ems_discount_scoal` (`energy_code`, `energy_name`, `coefficient_value`, `coefficient_unit`) VALUES ('300301', '汽油', 1.4714, 'kgce/kg');
  320. INSERT INTO `dim_ems_discount_scoal` (`energy_code`, `energy_name`, `coefficient_value`, `coefficient_unit`) VALUES ('25', '天然气', 1.33, 'kgce/㎡');
  321. INSERT INTO `dim_ems_discount_scoal` (`energy_code`, `energy_name`, `coefficient_value`, `coefficient_unit`) VALUES ('45', '电能', 0.1229, 'kgce/kW·h');
  322. INSERT INTO `dim_ems_discount_scoal` (`energy_code`, `energy_name`, `coefficient_value`, `coefficient_unit`) VALUES ('70', '新水', 0.7143, 'kgce/kg');
  323. -- ----------------------------
  324. -- 排放因子维表
  325. -- ----------------------------
  326. drop table if exists dim_ems_emission_factor;
  327. create table dim_ems_emission_factor (
  328. `id` bigint(20) not null auto_increment comment '序号',
  329. `region_code` varchar(8) not null comment '地区码',
  330. `region_name` varchar(16) not null comment '地区名称',
  331. `region_type` int not null comment '地区类型 0:国家,1:地区,2:省份,3:城市',
  332. `factor_value` double default null comment '因子值 单位: kgCO2/kWh',
  333. `factor_type` int default null comment '1:电力平均二氧化碳排放因子 2:电力平均二氧化碳排放因子(不含市场化交易的非化石能源电量)3:化石能源电力二氧化碳排放因子,',
  334. `version` varchar(64) default null comment '数据版本',
  335. primary key (`id`),
  336. unique key ux_ems_emission_factor(`region_code`,`region_type`,`factor_type`)
  337. ) engine=innodb auto_increment=1 comment = '排放因子维表';
  338. -- 排放因子初始数据
  339. INSERT INTO `dim_ems_emission_factor` (`region_code`, `region_name`, `region_type`, `factor_value`, `factor_type`, `version`) VALUES ('CN', '中国', '0', '0.5366', '1', '2022');
  340. -- ----------------------------
  341. -- 植物碳汇维表
  342. -- ----------------------------
  343. drop table if exists dim_plant_carbon_sink;
  344. create table dim_plant_carbon_sink (
  345. `id` bigint(20) not null auto_increment comment '序号',
  346. `plant_method` varchar(128) not null comment '种植方式',
  347. `carbon_quantity` double not null comment '固碳量 kgC02/m2',
  348. `version` varchar(64) default null comment '数据版本',
  349. primary key (`id`)
  350. ) engine=innodb auto_increment=1 comment = '植物碳汇维表';
  351. -- 植物碳汇维表初始数据
  352. INSERT INTO `dim_plant_carbon_sink` (`id`, `plant_method`, `carbon_quantity`, `version`) VALUES (1, '大小乔木、灌木、花草密植混种区(乔木平均种植间距)<3.0m,土壤深度>1.0m', '27.5', '江苏2023');
  353. INSERT INTO `dim_plant_carbon_sink` (`id`, `plant_method`, `carbon_quantity`, `version`) VALUES (2, '大小乔木密植混种区(平均种植间距)<3.0m,土壤深度>0.9m', '22.5', '江苏2023');
  354. INSERT INTO `dim_plant_carbon_sink` (`id`, `plant_method`, `carbon_quantity`, `version`) VALUES (3, '落叶大乔木(土壤深度>1.0m)', '20.2', '江苏2023');
  355. INSERT INTO `dim_plant_carbon_sink` (`id`, `plant_method`, `carbon_quantity`, `version`) VALUES (4, '落叶小乔木、针叶木或疏叶性乔木(土壤深度>1.0m)', '14.3', '江苏2023');
  356. INSERT INTO `dim_plant_carbon_sink` (`id`, `plant_method`, `carbon_quantity`, `version`) VALUES (5, '小棕榈类(土壤深度>1.0m)', '10.25', '江苏2023');
  357. INSERT INTO `dim_plant_carbon_sink` (`id`, `plant_method`, `carbon_quantity`, `version`) VALUES (6, '密植灌木丛(高约1.3m,土壤深度>0.5m)', '10.95', '江苏2023');
  358. INSERT INTO `dim_plant_carbon_sink` (`id`, `plant_method`, `carbon_quantity`, `version`) VALUES (7, '密植灌木丛(高约0.9m,土壤深度>0.5m)', '8.15', '江苏2023');
  359. INSERT INTO `dim_plant_carbon_sink` (`id`, `plant_method`, `carbon_quantity`, `version`) VALUES (8, '密植灌木丛(高约0.45m,土壤深度>0.5m)', '5.13', '江苏2023');
  360. INSERT INTO `dim_plant_carbon_sink` (`id`, `plant_method`, `carbon_quantity`, `version`) VALUES (9, '多年生蔓藤(以立体攀附面积计算,土壤深度>0.5m)', '2.58', '江苏2023');
  361. INSERT INTO `dim_plant_carbon_sink` (`id`, `plant_method`, `carbon_quantity`, `version`) VALUES (10, '高草花花圃或高茎野草地(高约1.0m,土壤深度>0.3m)', '1.15', '江苏2023');
  362. INSERT INTO `dim_plant_carbon_sink` (`id`, `plant_method`, `carbon_quantity`, `version`) VALUES (11, '一年生蔓藤、低草花花圃或低茎野草地(高约0.25m,土壤深度>0.3m)', '0.34', '江苏2023');
  363. -- ----------------------------
  364. -- 行政区划表
  365. -- ----------------------------
  366. DROP TABLE IF EXISTS `dim_gb_region`;
  367. CREATE TABLE `dim_gb_region` (
  368. `adcode` varchar(8) NOT NULL COMMENT '地区编码',
  369. `name` varchar(64) NOT NULL COMMENT '地区名称',
  370. `area_type` int(8) DEFAULT NULL COMMENT '1:省,2:直辖市/省会,3:地级市,4:区县/县级市',
  371. `parent_area` varchar(8) DEFAULT NULL COMMENT '父级地区编码',
  372. `parent_area_name` varchar(64) DEFAULT NULL COMMENT '父级地区名称',
  373. PRIMARY KEY (`adcode`) USING BTREE
  374. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='行政区编码表(GB_T 2260)';
  375. -- ----------------------------
  376. -- 区域对象表
  377. -- ----------------------------
  378. drop table if exists adm_area;
  379. create table adm_area (
  380. `id` bigint(20) not null auto_increment comment '序号',
  381. `area_code` varchar(32) not null comment '区域代码',
  382. `parent_code` varchar(32) default null comment '上级区域代码',
  383. `ancestors` varchar(1024) default null comment '祖籍列表',
  384. `area_name` varchar(64) not null comment '区域名称',
  385. `short_name` varchar(32) default null comment '区域简称',
  386. `desc` varchar(128) default null comment '区域描述',
  387. `order_num` int default null comment '显示顺序',
  388. `status` int default null comment '区域状态',
  389. primary key (`id`),
  390. unique key ux_area_code(`area_code`)
  391. ) engine=innodb auto_increment=1 comment = '区域对象表';
  392. -- ----------------------------
  393. -- 区域对象属性表
  394. -- ----------------------------
  395. drop table if exists adm_area_attr;
  396. create table adm_area_attr (
  397. `id` bigint(20) not null auto_increment comment '序号',
  398. `area_code` varchar(32) not null comment '区域代码',
  399. `attr_org` varchar(64) default null comment '所有单位',
  400. `mgr_org` varchar(64) default null comment '管理单位',
  401. `leader` varchar(64) default null comment '负责人',
  402. `phone` varchar(64) default null comment '联系电话',
  403. `open_date` date default null comment '开通时间',
  404. `floor_area` double default null comment '建筑面积(平方米 m²)',
  405. `usable_area` double default null comment '使用面积(平方米 m²)',
  406. `floor` int default null comment '楼层',
  407. `longitude` double default null comment '经度',
  408. `latitude` double default null comment '纬度',
  409. primary key (`id`),
  410. unique key ux_area_attr_code(`area_code`)
  411. ) engine=innodb auto_increment=1 comment = '区域对象属性表';
  412. -- ----------------------------
  413. -- 区域植物配置表
  414. -- ----------------------------
  415. drop table if exists adm_area_plant_rel;
  416. create table adm_area_plant_rel (
  417. `area_code` varchar(32) not null comment '区域代码',
  418. `plant_size` double not null comment '种植区域面积m²',
  419. `carbon_sink_id` bigint not null comment '固碳配置id',
  420. primary key (`area_code`, `carbon_sink_id`)
  421. ) engine=innodb auto_increment=1 comment = '区域植物配置表';
  422. -- ----------------------------
  423. -- 日期属性表
  424. -- ----------------------------
  425. DROP TABLE IF EXISTS `adm_date_attr`;
  426. CREATE TABLE `adm_date_attr` (
  427. `date` date NOT NULL COMMENT '日期',
  428. `week` INT NOT NULL COMMENT '星期几',
  429. `week_cn` VARCHAR(16) NOT NULL COMMENT '星期几(中文)',
  430. `type` VARCHAR(64) NOT NULL COMMENT '日期类型',
  431. `date_name` VARCHAR(64) NOT NULL COMMENT '日期名称',
  432. PRIMARY KEY (`date`)
  433. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='日期属性表';
  434. -- ----------------------------
  435. -- 天气状况分类与代码表
  436. -- ----------------------------
  437. DROP TABLE IF EXISTS `dim_ga_weather`;
  438. CREATE TABLE `dim_ga_weather` (
  439. `key` varchar(8) NOT NULL COMMENT '代码',
  440. `value` varchar(64) NOT NULL COMMENT '名称',
  441. `desc` varchar(256) DEFAULT NULL COMMENT '说明',
  442. PRIMARY KEY (`key`)
  443. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='天气状况代码表';
  444. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('1000', '天空状况', null);
  445. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('1100', '云量', '天空中云遮蔽的量');
  446. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('1101', '晴', '天空无云,或有零星云层,天空云量小于天空面积的1/10');
  447. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('1103', '多云', '天空有4~7成的中、低云或6~10成的高云');
  448. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('1106', '阴天', '天空阴暗,密布云层,或天空虽有云隙而仍感到阴暗(总云量8成以上),偶尔从云缝中可见到微弱阳光');
  449. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('2000', '降水现象', null);
  450. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('2100', '雨', null);
  451. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('2101', '小雨', '日降雨量不足10mm');
  452. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('2102', '中雨', '日降雨总量为10.0mm ~ 24.9mm');
  453. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('2103', '大雨', '日降雨总量为25.0mm ~ 49.9mm');
  454. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('2104', '暴雨', '日降雨总量在50.0mm以上');
  455. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('2111', '阵雨', '开始和停止都比较突然、强度变化大的液态降水');
  456. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('2121', '雷阵雨', '开始和停止都比较突然、强度变化大的液态降水,并伴有雷暴或闪电现象');
  457. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('2131', '冬雨', '由过冷水滴组成的,与温度低于0℃的物体');
  458. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('2200', '雪', null);
  459. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('2201', '小雪', '降雪融化成水相当0.1mm ~ 2.4mm降水量');
  460. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('2202', '中雪', '降雪融化成水相当2.5mm ~ 4.9mm降水量');
  461. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('2203', '大雪', '降雪融化成水相当5.0mm ~ 9.9mm降水量');
  462. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('2204', '暴雪', '降雪融化成水相当10mm降水量以上');
  463. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('2211', '雨夹雪', '半融化的雪(湿雪)或雨和雪同时下降');
  464. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('2300', '冰雹', '坚硬的球状、锥状或形状不规则的固态降水');
  465. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('2900', '其他降水现象', null);
  466. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('3000', '水汽凝结现象', '云除外');
  467. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('3100', '露', '空气中水汽在地面及近地面物体上凝结而成的水珠');
  468. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('3200', '霜冻', '空气中水汽在地面和近地面物体上凝华而成的白色松脆的冰晶,或由露冻结而成的水珠');
  469. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('3900', '其他水气凝结现象', null);
  470. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('4000', '视程障碍现象', null);
  471. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('4100', '雾', '悬浮在贴近地面的大气中的大量微细水滴(或冰晶)的可见集合体');
  472. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('4101', '轻雾', '能见度在1km ~ 10km,又称霭');
  473. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('4102', '大雾', '能见度在1km以下');
  474. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('4103', '浓雾', '能见度在500m以下');
  475. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('4200', '霾', '空气中的灰尘、硫酸、硝酸、有机碳氢化合物等粒子非水成物组成的气溶胶系统造成的视程障碍,如果水平能见度小于10km时称为霾或灰霾');
  476. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('4300', '沙尘', null);
  477. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('4301', '浮尘', '尘沙浮游在空中,使水平能见度小于10km');
  478. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('4302', '扬沙', '风将地面尘、沙吹起,使空气相当浑浊水平能见度在1km ~ 10km');
  479. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('4303', '沙尘暴', '强风将地面尘、沙吹起,使空气相当浑浊水平能见度小于1km');
  480. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('4304', '强沙尘暴','大风将地面尘、沙吹起,使空气相当浑浊水平能见度小于500m');
  481. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('4305', '特强沙尘暴', '狂风将地面尘、沙吹起,使空气相当浑浊水平能见度小于50m');
  482. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('4900', '其他视程障碍现象', null);
  483. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('5000', '雷电现象', null);
  484. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('5100', '雷电', null);
  485. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('5101', '雷暴', '积雨云云中、云间或云地之间产生的放电现象。表现为闪电兼有雷声,有时亦可只闻雷声而不见闪电');
  486. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('5105', '闪电', '积雨云云中、云间或云地之间产生放电时伴随的电光,但不闻雷声');
  487. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('5900', '其他雷电现象', null);
  488. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9000', '其他天气现象', null);
  489. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9100', '风', '风力等级为薄福风力等级');
  490. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9101', '1级(软风)', '烟稍斜,风速0.3m/s ~ 1.5m/s');
  491. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9102', '2级(轻风)', '感觉有风树叶响,风速1.6m/s ~ 3.3m/s');
  492. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9103', '3级(微风)', '旌旗展开树枝摇晃,风速3.4m/s ~ 5.4m/s');
  493. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9104', '4级(和风)', '吹起尘土,风速 5.5m/s ~ 7.9m/s');
  494. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9105', '5级(清劲风)', '小树摇摆水起波,风速8.0m/s ~ 10.7m/s');
  495. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9106', '6级(强风)', '电线有声大树摇,风中撑伞难行,风速10.8m/s~13.8m/s');
  496. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9107', '7级(疾风)', '逆风步行困难,风速13.9m/s ~ 17.1m/s');
  497. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9108', '8级(大风)', '折毁树枝,迎风差点走不动,风速17.2m/s ~ 20.7m/s');
  498. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9109', '9级(烈风)', '小损房屋,风速20.8m/s ~ 24.4m/s');
  499. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9110', '10级(狂风)', '拔起树木,风速24.5m/s ~ 28.4m/s');
  500. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9111', '11级(暴风)', '水面波峰全呈飞沫,风速28.5m/s ~ 32.6m/s');
  501. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9112', '12级(飓风、台风)', '水面波浪滔天,风速 32.7m/s ~ 36.9m/s');
  502. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9113', '13级', '风速37.0m/s ~ 41.4m/s');
  503. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9114', '14级', '风速41.5m/s ~ 46.1m/s');
  504. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9115', '15级', '风速46.2m/s ~ 50.9m/s');
  505. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9116', '16级', '风速51.0m/s ~ 56.0m/s');
  506. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9117', '17级', '风速56.1m/s ~ 61.2m/s');
  507. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9191', '0级(无风)', '静,烟直上,风速0.0m/s ~ 0.2m/s');
  508. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9192', '1-6级', '适用于笼统描述1级(含1级)到6级(不含6级)之间的风');
  509. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9193', '6-12级', '适用于笼统描述6级(含6级)到12级(不含12级)之间的风');
  510. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9194', '12-17级', '适用于笼统描述12级(含12级)到17级(不含17级)之间的风');
  511. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9201', '飑', '风向突变,风速剧增的天气现象');
  512. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9301', '龙卷', '一种小范围强烈旋风,风速一般为50m/s ~ 150m/s');
  513. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9401', '积雪', '雪覆盖地面达到观测点四周能见面积一半以上');
  514. INSERT INTO `dim_ga_weather` (`key`, `value`, `desc`) VALUES ('9501', '结冰', '露天水冻结成冰');
  515. -- ----------------------------
  516. -- 区域天气实况表
  517. -- ----------------------------
  518. DROP TABLE IF EXISTS `adm_area_weather_rt`;
  519. CREATE TABLE `adm_area_weather_rt` (
  520. `adcode` varchar(16) NOT NULL COMMENT '行政区划编码',
  521. `area_name` varchar(32) NOT NULL COMMENT '区域名称',
  522. `date` date NOT NULL COMMENT '日期',
  523. `weather_type` varchar(8) NOT NULL COMMENT '天气代码',
  524. `weather_cn` varchar(128) DEFAULT NULL COMMENT '天气描述',
  525. `temperature` double DEFAULT NULL COMMENT '温度',
  526. `humidity` int DEFAULT NULL COMMENT '湿度',
  527. `wind_power` varchar(8) DEFAULT NULL COMMENT '风力级别',
  528. `wind_direction` varchar(64) DEFAULT NULL COMMENT '风向',
  529. `report_time` timestamp DEFAULT NULL COMMENT '数据时间',
  530. `create_time` timestamp DEFAULT NULL COMMENT '采集时间',
  531. PRIMARY KEY (`adcode`,`date`)
  532. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='区域天气实况';
  533. -- ----------------------------
  534. -- 区域天气预报
  535. -- ----------------------------
  536. DROP TABLE IF EXISTS `adm_area_weather_forecast`;
  537. CREATE TABLE `adm_area_weather_forecast` (
  538. `adcode` varchar(16) NOT NULL COMMENT '行政区划编码',
  539. `area_name` varchar(32) NOT NULL COMMENT '区域名称',
  540. `date` date NOT NULL COMMENT '日期',
  541. `day_weather_type` varchar(8) DEFAULT NULL COMMENT '日间天气代码',
  542. `day_weather_cn` varchar(128) DEFAULT NULL COMMENT '日间天气描述',
  543. `night_weather_type` varchar(8) DEFAULT NULL COMMENT '夜间天气代码',
  544. `night_weather_cn` varchar(128) DEFAULT NULL COMMENT '夜间天气描述',
  545. `day_temp` double DEFAULT NULL COMMENT '日间气温',
  546. `night_temp` double DEFAULT NULL COMMENT '夜间气温',
  547. `day_wind_power` varchar(8) DEFAULT NULL COMMENT '日间风力',
  548. `night_wind_power` varchar(8) DEFAULT NULL COMMENT '夜间风力',
  549. `day_wind_dir` varchar(64) DEFAULT NULL COMMENT '日间风向',
  550. `night_wind_dir` varchar(64) DEFAULT NULL COMMENT '夜间风向',
  551. `report_time` timestamp DEFAULT NULL COMMENT '数据时间',
  552. `create_time` timestamp DEFAULT NULL COMMENT '采集时间',
  553. PRIMARY KEY (`adcode`,`date`)
  554. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='区域天气预报';
  555. -- ----------------------------
  556. -- 定时任务调度表
  557. -- ----------------------------
  558. drop table if exists sys_job;
  559. create table sys_job (
  560. job_id bigint(20) not null auto_increment comment '任务ID',
  561. job_name varchar(64) default '' comment '任务名称',
  562. job_group varchar(64) default 'DEFAULT' comment '任务组名',
  563. invoke_target varchar(500) not null comment '调用目标字符串',
  564. cron_expression varchar(255) default '' comment 'cron执行表达式',
  565. misfire_policy varchar(20) default '3' comment '计划执行错误策略(1立即执行 2执行一次 3放弃执行)',
  566. concurrent char(1) default '1' comment '是否并发执行(0允许 1禁止)',
  567. status char(1) default '0' comment '状态(0正常 1暂停)',
  568. create_by varchar(64) default '' comment '创建者',
  569. create_time datetime comment '创建时间',
  570. update_by varchar(64) default '' comment '更新者',
  571. update_time datetime comment '更新时间',
  572. remark varchar(500) default '' comment '备注信息',
  573. primary key (job_id, job_name, job_group)
  574. ) engine=innodb auto_increment=100 comment = '定时任务调度表';
  575. -- ----------------------------
  576. -- 能源设施表
  577. -- ----------------------------
  578. drop table if exists adm_ems_facs;
  579. create table adm_ems_facs (
  580. `id` bigint(20) not null auto_increment comment '序号',
  581. `facs_code` varchar(16) not null comment '设施代码',
  582. `facs_name` varchar(32) not null comment '设施名称',
  583. `facs_category` varchar(32) not null comment '设施分类',
  584. `facs_subcategory` varchar(32) not null comment '设施子类',
  585. `enable` int default '0' comment '启用状态0-停用,1-启用',
  586. `ref_area` varchar(32) not null comment '归属区域代码',
  587. `create_time` datetime default CURRENT_TIMESTAMP comment '创建时间',
  588. `update_time` datetime default CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP comment '更新时间',
  589. primary key (`id`),
  590. unique key ux_ems_facs_code(`facs_code`)
  591. ) engine=innodb auto_increment=1 comment = '能源设施表';
  592. -- ----------------------------
  593. -- 能源设备表
  594. -- ----------------------------
  595. drop table if exists adm_ems_device;
  596. create table adm_ems_device (
  597. `id` bigint(20) not null auto_increment comment '序号',
  598. `device_code` varchar(64) not null comment '设备代码',
  599. `device_name` varchar(32) not null comment '设备名称',
  600. `device_brand` varchar(128) default null comment '设备品牌',
  601. `device_spec` varchar(128) default null comment '设备型号',
  602. `device_status` int default null comment '设备状态',
  603. `location` varchar(200) default null comment '安装位置',
  604. `location_ref` varchar(64) default null comment '安装位置关联区域',
  605. `area_code` varchar(32) default null comment '归属地块代码',
  606. `device_model` varchar(32) default null comment '设备模型',
  607. `ref_facs` varchar(64) default null comment '归属设施代码',
  608. `ps_code` varchar(16) default null comment '工艺标识',
  609. `subsystem_code` varchar(16) default null comment '子系统名称',
  610. `create_time` datetime default CURRENT_TIMESTAMP comment '创建时间',
  611. `update_time` datetime default CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP comment '更新时间',
  612. primary key (`id`),
  613. unique key ux_device_code(`device_code`),
  614. index idx_device_code (device_code)
  615. ) engine=innodb auto_increment=1 comment = '能源设备表';
  616. -- ----------------------------
  617. -- 计量设备表
  618. -- ----------------------------
  619. drop table if exists adm_meter_device;
  620. create table adm_meter_device (
  621. `id` bigint(20) not null auto_increment comment '序号',
  622. `device_code` varchar(32) not null comment '设备代码',
  623. `device_model` varchar(32) not null comment '设备模型',
  624. `area_code` varchar(32) default null comment '区域代码',
  625. `device_name` varchar(64) default null comment '设备别名',
  626. `device_enable` int not null comment '设备启用0:未启用,1:启用',
  627. `location_ref` varchar(64) default null comment '归属子区',
  628. `location` varchar(128) default null comment '安装位置',
  629. `meter_cls` int not null comment '计量类别25-天然气 45-电 70-水',
  630. `col_cycle` int default null comment '采集周期',
  631. `col_mode` int default null comment '采集方式',
  632. `magnification` int default 1 comment '倍率',
  633. `spec_desc` varchar(128) default null comment '规格描述',
  634. primary key (`id`),
  635. unique key ux_meter_device(`device_model`,`device_code`)
  636. ) engine=innodb auto_increment=1 comment = '计量设备表';
  637. -- ----------------------------
  638. -- 计量设备绑定边界对象关系表
  639. -- ----------------------------
  640. drop table if exists adm_meter_boundary_rel;
  641. create table adm_meter_boundary_rel (
  642. `id` bigint(20) not null auto_increment comment '序号',
  643. `obj_type` int not null comment '对象类型 1-区域,2-设施',
  644. `boundary_obj` varchar(64) not null comment '边界对象',
  645. `meter_cls` int not null comment '计量介质',
  646. `meter_device` varchar(64) not null comment '计量设备',
  647. primary key (`id`),
  648. unique key ux_meter_device(`obj_type`,`boundary_obj`,`meter_cls`,`meter_device`)
  649. ) engine=innodb auto_increment=1 comment = '计量设备绑定边界对象关系表';
  650. -- ----------------------------
  651. -- 能源对象模型表
  652. -- ----------------------------
  653. drop table if exists adm_ems_obj_model;
  654. create table adm_ems_obj_model (
  655. `id` bigint(20) not null auto_increment comment '序号',
  656. `model_code` varchar(64) not null comment '模型code',
  657. `model_name` varchar(128) not null comment '模型名称',
  658. `obj_type` int not null comment '对象类型',
  659. `ability_handler` varchar(2048) default null comment '能力处理handler',
  660. `event_handler` varchar(2048) default null comment '事件处理handler',
  661. primary key (`id`),
  662. unique key ux_ems_obj_attr(`model_code`)
  663. ) engine=innodb auto_increment=1 comment = '能源对象模型表';
  664. -- 对象模型初始数据
  665. # INSERT INTO `adm_ems_obj_model` (`model_code`, `model_name`, `obj_type`, `ability_handler`, `event_handler`) VALUES ('M_W2_T', '变压器设备模型', 2, null, null);
  666. # INSERT INTO `adm_ems_obj_model` (`model_code`, `model_name`, `obj_type`, `ability_handler`, `event_handler`) VALUES ('M_W2_AP', '配电柜模型', 2, null, null);
  667. # INSERT INTO `adm_ems_obj_model` (`model_code`, `model_name`, `obj_type`, `ability_handler`, `event_handler`) VALUES ('M_W2_QR', '漏电保护器模型', 2, null, null);
  668. # INSERT INTO `adm_ems_obj_model` (`model_code`, `model_name`, `obj_type`, `ability_handler`, `event_handler`) VALUES ('M_W2_QF', '断路器模型', 2, null, null);
  669. -- ----------------------------
  670. -- 能源对象属性表
  671. -- ----------------------------
  672. drop table if exists adm_ems_obj_attr;
  673. create table adm_ems_obj_attr (
  674. `id` bigint(20) not null auto_increment comment '序号',
  675. `model_code` varchar(64) not null comment '模型code',
  676. `attr_group` varchar(128) not null comment '属性分组',
  677. `attr_key` varchar(128) not null comment '属性标识',
  678. `attr_name` varchar(256) default null comment '属性名称',
  679. `attr_unit` text default null comment '属性单位',
  680. `attr_value_type` varchar(32) default null comment '属性单位值类型',
  681. primary key (`id`),
  682. unique key ux_ems_obj_attr(`model_code`, `attr_key`)
  683. ) engine=innodb auto_increment=1 comment = '能源对象属性表';
  684. -- ----------------------------
  685. -- 能源对象属性值表
  686. -- ----------------------------
  687. drop table if exists adm_ems_obj_attr_enum;
  688. create table adm_ems_obj_attr_enum (
  689. `id` bigint(20) not null auto_increment comment '序号',
  690. `model_code` varchar(64) not null comment '模型code',
  691. `attr_key` varchar(128) not null comment '属性标识',
  692. `attr_value` varchar(32) not null comment '属性枚举值',
  693. `attr_value_name` varchar(32) default null comment '属性枚举值描述',
  694. primary key (`id`),
  695. unique key ux_ems_obj_attr_value(`model_code`, `attr_key`, `attr_value`)
  696. ) engine=innodb auto_increment=1 comment = '能源对象属性枚举表';
  697. -- ----------------------------
  698. -- 能源对象属性值表
  699. -- ----------------------------
  700. drop table if exists adm_ems_obj_attr_value;
  701. create table adm_ems_obj_attr_value (
  702. `id` bigint(20) not null auto_increment comment '序号',
  703. `obj_code` varchar(64) not null comment '对象代码',
  704. `model_code` varchar(64) not null comment '模型code',
  705. `attr_key` varchar(128) not null comment '属性标识',
  706. `attr_value` text default null comment '属性值',
  707. `update_time` datetime default CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP comment '更新时间',
  708. primary key (`id`),
  709. unique key ux_ems_obj_attr_value(`obj_code`, `model_code`, `attr_key`)
  710. ) engine=innodb auto_increment=1 comment = '能源对象属性值表';
  711. -- ----------------------------
  712. -- 能源对象能力表
  713. -- ----------------------------
  714. drop table if exists adm_ems_obj_ability;
  715. create table adm_ems_obj_ability (
  716. `id` bigint(20) not null auto_increment comment '序号',
  717. `model_code` varchar(64) not null comment '模型code',
  718. `ability_key` varchar(128) not null comment '能力键',
  719. `ability_name` varchar(256) default null comment '能力名称',
  720. `ability_desc` varchar(1024) default null comment '能力描述',
  721. `param_definition` text default null comment '参数定义',
  722. `hidden_flag` int default 0 comment '隐藏标记',
  723. primary key (`id`),
  724. unique key ux_ems_obj_ability(`model_code`, `ability_key`)
  725. ) engine=innodb auto_increment=1 comment = '能源对象能力表';
  726. -- ----------------------------
  727. -- 能源对象能力调用日志表
  728. -- ----------------------------
  729. drop table if exists adm_ems_obj_ability_call_log;
  730. create table adm_ems_obj_ability_call_log (
  731. `id` bigint(20) not null auto_increment comment '序号',
  732. `obj_code` varchar(64) not null comment '对象代码',
  733. `model_code` varchar(64) not null comment '模型code',
  734. `ability_key` varchar(128) not null comment '能力键',
  735. `call_time` datetime not null comment '调用时间',
  736. `call_payload` text default null comment '调用参数',
  737. `call_status` int not null comment '调用状态',
  738. `res_time` datetime default null comment '响应时间',
  739. `res_payload` mediumtext default null comment '响应内容',
  740. primary key (`id`),
  741. INDEX idx_covering (model_code,call_time,obj_code,ability_key,call_status, id)
  742. ) engine=innodb auto_increment=1 comment = '能源对象能力调用日志表';
  743. -- ----------------------------
  744. -- 能源设施事件表
  745. -- ----------------------------
  746. drop table if exists adm_ems_obj_event;
  747. create table adm_ems_obj_event (
  748. `id` bigint(20) not null auto_increment comment '序号',
  749. `model_code` varchar(64) not null comment '模型code',
  750. `event_key` varchar(128) not null comment '事件名称',
  751. `event_type` int not null comment '事件类型',
  752. `event_name` varchar(256) default null comment '事件名称',
  753. `event_desc` varchar(1024) default null comment '事件名称',
  754. `event_code` varchar(128) default null comment '事件代码',
  755. `ext_event_code` varchar(128) default null comment '外系统事件代码',
  756. primary key (`id`),
  757. unique key ux_ems_obj_event(`model_code`, `event_key`)
  758. ) engine=innodb auto_increment=1 comment = '能源对象事件表';
  759. -- ----------------------------
  760. -- 能源对象能力事件日志表
  761. -- ----------------------------
  762. drop table if exists adm_ems_obj_event_log;
  763. create table adm_ems_obj_event_log (
  764. `id` bigint(20) not null auto_increment comment '序号',
  765. `obj_code` varchar(64) not null comment '对象代码',
  766. `model_code` varchar(64) not null comment '模型code',
  767. `event_key` varchar(128) not null comment '事件标识',
  768. `event_time` datetime not null comment '事件时间',
  769. `event_detail` text default null comment '事件详情',
  770. primary key (`id`),
  771. key i_obj_event_log(`obj_code`, `event_time`, `event_key`)
  772. ) engine=innodb auto_increment=1 comment = '能源对象事件日志表';
  773. -- ----------------------------
  774. -- 能源子系统表
  775. -- ----------------------------
  776. drop table if exists adm_ems_subsystem;
  777. create table adm_ems_subsystem (
  778. `id` bigint(20) not null auto_increment comment '序号',
  779. `system_code` varchar(16) not null comment '系统代码',
  780. `system_name` varchar(32) not null comment '系统名称',
  781. `short_name` varchar(16) default null comment '系统简称',
  782. `model_code` varchar(64) not null comment '模型code',
  783. `man_facturer` varchar(64) default null comment '厂商',
  784. `contact_person` varchar(32) default null comment '联系人',
  785. `contact_number` varchar(128) default null comment '联系电话',
  786. `maintainer_person` varchar(32) default null comment '维护人',
  787. `maintainer_number` varchar(128) default null comment '维护电话',
  788. `descr` varchar(1024) default null comment '备注说明',
  789. primary key (`id`),
  790. unique key ux_ems_subsystem_code(`system_code`)
  791. ) engine=innodb auto_increment=1 comment = '能源子系统表';
  792. -- ----------------------------
  793. -- 能源设施能流关系表
  794. -- ----------------------------
  795. DROP TABLE IF EXISTS adm_ems_flow_rel;
  796. CREATE TABLE adm_ems_flow_rel (
  797. `id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '序号',
  798. `export_obj` VARCHAR(64) NOT NULL COMMENT '能源输出对象代码',
  799. `export_obj_name` VARCHAR(128) DEFAULT NULL COMMENT '能源输出对象名称',
  800. `export_obj_type` INT NOT NULL COMMENT '能源输出对象类型 1-设施 2-设备',
  801. `input_obj` VARCHAR(64) NOT NULL COMMENT '能源流入对象代码',
  802. `input_obj_name` VARCHAR(128) DEFAULT NULL COMMENT '能源流入对象名称',
  803. `input_obj_type` INT NOT NULL COMMENT '能源输入对象类型 1-设施 2-设备',
  804. `ems_cls` VARCHAR(16) NOT NULL COMMENT '能源流动介质代码',
  805. `ems_cls_name` VARCHAR(64) DEFAULT NULL COMMENT '能源流动介质名称',
  806. `flow_desc` VARCHAR(256) DEFAULT NULL COMMENT '能流描述',
  807. `flow_capacity` DECIMAL(10,2) DEFAULT NULL COMMENT '流动容量/功率',
  808. `flow_unit` VARCHAR(16) DEFAULT NULL COMMENT '容量单位',
  809. `area_code` VARCHAR(32) DEFAULT NULL COMMENT '所属区域代码',
  810. `enable_status` INT DEFAULT 1 COMMENT '启用状态 0-禁用 1-启用',
  811. `create_time` DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  812. `update_time` DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  813. PRIMARY KEY (`id`),
  814. UNIQUE KEY `ux_flow_rel` (`export_obj`, `export_obj_type`, `input_obj`, `input_obj_type`, `ems_cls`),
  815. KEY `idx_export_obj` (`export_obj`, `export_obj_type`),
  816. KEY `idx_input_obj` (`input_obj`, `input_obj_type`),
  817. KEY `idx_area_code` (`area_code`)
  818. ) ENGINE=INNODB AUTO_INCREMENT=1 COMMENT='能源流动关系表';
  819. -- ----------------------------
  820. -- 能源策略表
  821. -- ----------------------------
  822. drop table if exists adm_op_energy_strategy;
  823. CREATE TABLE adm_op_energy_strategy (
  824. `id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '序号',
  825. `area_code` VARCHAR(32) NOT NULL COMMENT '地块代码',
  826. `strategy_code` VARCHAR(64) NOT NULL COMMENT '策略代码',
  827. `strategy_name` VARCHAR(64) NOT NULL COMMENT '策略名称',
  828. `scene_type` VARCHAR(32) DEFAULT NULL COMMENT '场景类型:PV_ESS-源网协调,DEMAND_RESP-源荷互动,PEAK_VALLEY-网储互动,EMERGENCY-应急保供,ENERGY_SAVE-节能优化',
  829. `strategy_category` VARCHAR(32) DEFAULT NULL COMMENT '策略分类:AUTO-自动,MANUAL-手动,SCHEDULE-定时,EVENT-事件',
  830. `trigger_type` INT DEFAULT NULL COMMENT '触发类型:1-事件触发,2-定时触发,3-手动触发,4-条件触发',
  831. `trigger_config` TEXT DEFAULT NULL COMMENT '触发配置(JSON)',
  832. `strategy_state` INT DEFAULT 0 COMMENT '策略状态:0-停用,1-启用,2-调试',
  833. `priority` INT DEFAULT 50 COMMENT '优先级:0-100,数值越大优先级越高',
  834. `strategy_desc` VARCHAR(256) DEFAULT NULL COMMENT '策略描述',
  835. `exec_mode` INT DEFAULT NULL COMMENT '执行模式:1-串行,2-并行,99-手动',
  836. `timeout` INT DEFAULT 300 COMMENT '超时时间(秒)',
  837. `retry_times` INT DEFAULT 0 COMMENT '失败重试次数',
  838. `last_exec_time` DATETIME DEFAULT NULL COMMENT '最后执行时间',
  839. `last_exec_result` INT DEFAULT NULL COMMENT '最后执行结果:0-成功,1-失败',
  840. `exec_count` INT DEFAULT 0 COMMENT '执行次数',
  841. `success_count` INT DEFAULT 0 COMMENT '成功次数',
  842. `fail_count` INT DEFAULT 0 COMMENT '失败次数',
  843. `version` INT DEFAULT 1 COMMENT '版本号',
  844. `create_by` VARCHAR(64) DEFAULT NULL COMMENT '创建人',
  845. `create_time` DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  846. `update_by` VARCHAR(64) DEFAULT NULL COMMENT '更新人',
  847. `update_time` DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  848. PRIMARY KEY (`id`),
  849. UNIQUE KEY `ux_strategy_code` (`strategy_code`),
  850. KEY `idx_area_code` (`area_code`),
  851. KEY `idx_trigger_type` (`trigger_type`),
  852. KEY `idx_strategy_state` (`strategy_state`)
  853. ) ENGINE=INNODB AUTO_INCREMENT=1 COMMENT='能源策略表';
  854. -- ----------------------------
  855. -- 能源策略模板表
  856. -- ----------------------------
  857. DROP TABLE IF EXISTS adm_op_energy_strategy_template;
  858. CREATE TABLE adm_op_energy_strategy_template (
  859. `id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '序号',
  860. `template_code` VARCHAR(32) NOT NULL COMMENT '模板代码',
  861. `template_name` VARCHAR(64) NOT NULL COMMENT '模板名称',
  862. `scene_type` VARCHAR(32) NOT NULL COMMENT '场景类型',
  863. `description` VARCHAR(512) DEFAULT NULL COMMENT '模板描述',
  864. `template_data` LONGTEXT NOT NULL COMMENT '模板数据(JSON,包含触发器、步骤、上下文变量)',
  865. `icon` VARCHAR(64) DEFAULT NULL COMMENT '图标',
  866. `cover_image` VARCHAR(256) DEFAULT NULL COMMENT '封面图片',
  867. `tags` VARCHAR(256) DEFAULT NULL COMMENT '标签(逗号分隔)',
  868. `applicable_devices` VARCHAR(512) DEFAULT NULL COMMENT '适用设备类型(逗号分隔)',
  869. `sort_order` INT DEFAULT 0 COMMENT '排序',
  870. `use_count` INT DEFAULT 0 COMMENT '使用次数',
  871. `is_system` INT DEFAULT 0 COMMENT '是否系统预置:0-否,1-是',
  872. `is_public` INT DEFAULT 1 COMMENT '是否公开:0-否,1-是',
  873. `status` INT DEFAULT 1 COMMENT '状态:0-禁用,1-启用',
  874. `create_by` VARCHAR(64) DEFAULT NULL COMMENT '创建人',
  875. `create_time` DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  876. `update_by` VARCHAR(64) DEFAULT NULL COMMENT '更新人',
  877. `update_time` DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  878. PRIMARY KEY (`id`),
  879. UNIQUE KEY `ux_template_code` (`template_code`),
  880. KEY `idx_scene_type` (`scene_type`),
  881. KEY `idx_is_system` (`is_system`),
  882. KEY `idx_status` (`status`)
  883. ) ENGINE=INNODB AUTO_INCREMENT=1 COMMENT='策略模板表';
  884. -- 策略预置模板
  885. -- ----------------------------------------
  886. INSERT INTO adm_op_energy_strategy_template
  887. (template_code, template_name, scene_type, description, template_data, icon, tags, applicable_devices, sort_order, is_system, status)
  888. VALUES
  889. -- 光储联动模板
  890. ('TPL_PV_ESS_BASIC', '光储联动-基础模板', 'PV_ESS',
  891. '当光伏发电功率超过负荷需求时,自动将多余电量存入储能;当光伏发电不足时,从储能放电补充。',
  892. '{
  893. "triggers": [
  894. {"triggerType": "ATTR", "triggerName": "光伏功率变化", "sourceObjType": 2, "attrKey": "activePower", "conditionExpr": "{\"left\":\"activePower\",\"op\":\">\",\"right\":0}"}
  895. ],
  896. "steps": [
  897. {"stepType": "CONDITION", "stepName": "判断光伏功率", "stepIndex": 1, "conditionExpr": "{\"left\":\"pv.activePower\",\"op\":\">\",\"right\":\"load.activePower\"}"},
  898. {"stepType": "ABILITY", "stepName": "储能充电", "stepIndex": 2, "abilityKey": "charge", "paramSource": "CONTEXT"},
  899. {"stepType": "ABILITY", "stepName": "储能放电", "stepIndex": 3, "abilityKey": "discharge", "paramSource": "CONTEXT"}
  900. ],
  901. "context": [
  902. {"varKey": "pvPower", "varName": "光伏功率", "varType": "INPUT", "dataType": "NUMBER"},
  903. {"varKey": "loadPower", "varName": "负荷功率", "varType": "INPUT", "dataType": "NUMBER"},
  904. {"varKey": "essSoc", "varName": "储能SOC", "varType": "INPUT", "dataType": "NUMBER"}
  905. ]
  906. }',
  907. 'el-icon-sunny', '光伏,储能,联动', 'PV,ESS', 1, 1, 1),
  908. -- 削峰填谷模板
  909. ('TPL_PEAK_VALLEY', '削峰填谷-定时调度', 'PEAK_VALLEY',
  910. '根据电价时段自动调度储能充放电:低谷时段充电,高峰时段放电,实现电费优化。',
  911. '{
  912. "triggers": [
  913. {"triggerType": "TIME", "triggerName": "谷时充电", "conditionExpr": "{\"cron\":\"0 0 23 * * ?\"}"},
  914. {"triggerType": "TIME", "triggerName": "峰时放电", "conditionExpr": "{\"cron\":\"0 0 10 * * ?\"}"}
  915. ],
  916. "steps": [
  917. {"stepType": "CONDITION", "stepName": "检查SOC", "stepIndex": 1, "conditionExpr": "{\"left\":\"ess.soc\",\"op\":\"<\",\"right\":90}"},
  918. {"stepType": "ABILITY", "stepName": "储能充电", "stepIndex": 2, "abilityKey": "charge", "abilityParam": "{\"power\": 100}"},
  919. {"stepType": "DELAY", "stepName": "等待充电完成", "stepIndex": 3, "delaySeconds": 3600}
  920. ],
  921. "context": [
  922. {"varKey": "targetSoc", "varName": "目标SOC", "varType": "INPUT", "dataType": "NUMBER", "defaultValue": "90"},
  923. {"varKey": "chargePower", "varName": "充电功率", "varType": "INPUT", "dataType": "NUMBER", "defaultValue": "100"}
  924. ]
  925. }',
  926. 'el-icon-data-analysis', '削峰填谷,电价优化,储能', 'ESS', 2, 1, 1),
  927. -- 需求响应模板
  928. ('TPL_DEMAND_RESP', '需求响应-负荷控制', 'DEMAND_RESP',
  929. '当收到电网需求响应信号时,自动降低非关键负荷用电,并启动储能放电支撑。',
  930. '{
  931. "triggers": [
  932. {"triggerType": "EVENT", "triggerName": "需求响应信号", "sourceObjType": 3, "eventKey": "demandResponse"}
  933. ],
  934. "steps": [
  935. {"stepType": "PARALLEL", "stepName": "并行执行", "stepIndex": 1},
  936. {"stepType": "ABILITY", "stepName": "降低空调负荷", "stepIndex": 2, "parentStepCode": "STEP_1", "abilityKey": "setTemperature", "abilityParam": "{\"temp\": 26}"},
  937. {"stepType": "ABILITY", "stepName": "调暗照明", "stepIndex": 3, "parentStepCode": "STEP_1", "abilityKey": "dim", "abilityParam": "{\"level\": 60}"},
  938. {"stepType": "ABILITY", "stepName": "储能放电", "stepIndex": 4, "abilityKey": "discharge", "paramSource": "STATIC"}
  939. ],
  940. "context": [
  941. {"varKey": "responseLevel", "varName": "响应级别", "varType": "INPUT", "dataType": "NUMBER"},
  942. {"varKey": "duration", "varName": "响应时长", "varType": "INPUT", "dataType": "NUMBER"}
  943. ]
  944. }',
  945. 'el-icon-s-marketing', '需求响应,负荷控制,电网互动', 'ESS,HVAC,LIGHT', 3, 1, 1),
  946. -- 应急保供模板
  947. ('TPL_EMERGENCY', '应急保供-电网故障切换', 'EMERGENCY',
  948. '当检测到电网故障时,自动切换到储能供电模式,保障关键负荷持续运行。',
  949. '{
  950. "triggers": [
  951. {"triggerType": "EVENT", "triggerName": "电网故障", "sourceObjType": 2, "eventKey": "gridFault"}
  952. ],
  953. "steps": [
  954. {"stepType": "ABILITY", "stepName": "切断非关键负荷", "stepIndex": 1, "abilityKey": "disconnect"},
  955. {"stepType": "DELAY", "stepName": "等待切换", "stepIndex": 2, "delaySeconds": 2},
  956. {"stepType": "ABILITY", "stepName": "启动储能放电", "stepIndex": 3, "abilityKey": "discharge", "abilityParam": "{\"mode\": \"island\"}"},
  957. {"stepType": "ABILITY", "stepName": "发送告警通知", "stepIndex": 4, "abilityKey": "sendAlert"}
  958. ],
  959. "context": [
  960. {"varKey": "gridStatus", "varName": "电网状态", "varType": "INPUT", "dataType": "STRING"},
  961. {"varKey": "essAvailable", "varName": "储能可用", "varType": "INPUT", "dataType": "BOOLEAN"}
  962. ]
  963. }',
  964. 'el-icon-warning-outline', '应急,故障切换,保供', 'ESS,GRID', 4, 1, 1),
  965. -- 节能优化模板
  966. ('TPL_ENERGY_SAVE', '节能优化-智能照明', 'ENERGY_SAVE',
  967. '根据环境光照和人员存在情况,自动调节照明亮度,实现节能优化。',
  968. '{
  969. "triggers": [
  970. {"triggerType": "ATTR", "triggerName": "光照变化", "sourceObjType": 2, "attrKey": "illuminance"},
  971. {"triggerType": "ATTR", "triggerName": "人员检测", "sourceObjType": 2, "attrKey": "occupancy"}
  972. ],
  973. "steps": [
  974. {"stepType": "CONDITION", "stepName": "检查人员存在", "stepIndex": 1, "conditionExpr": "{\"left\":\"sensor.occupancy\",\"op\":\"==\",\"right\":true}"},
  975. {"stepType": "CONDITION", "stepName": "检查光照不足", "stepIndex": 2, "conditionExpr": "{\"left\":\"sensor.illuminance\",\"op\":\"<\",\"right\":300}"},
  976. {"stepType": "ABILITY", "stepName": "开启照明", "stepIndex": 3, "abilityKey": "setLevel", "abilityParam": "{\"level\": 80}"}
  977. ],
  978. "context": [
  979. {"varKey": "targetIlluminance", "varName": "目标照度", "varType": "INPUT", "dataType": "NUMBER", "defaultValue": "500"}
  980. ]
  981. }',
  982. 'el-icon-odometer', '节能,照明,智能控制', 'LIGHT,SENSOR', 5, 1, 1);
  983. -- ----------------------------
  984. -- 策略触发条件表
  985. -- ----------------------------
  986. drop table if exists adm_op_energy_strategy_trigger;
  987. CREATE TABLE adm_op_energy_strategy_trigger (
  988. `id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '序号',
  989. `strategy_code` VARCHAR(64) NOT NULL COMMENT '策略代码',
  990. `trigger_name` VARCHAR(64) NOT NULL COMMENT '触发器名称',
  991. `trigger_type` VARCHAR(32) NOT NULL COMMENT '触发类型:EVENT-事件,ATTR-属性变化,TIME-时间,CONDITION-条件',
  992. `source_obj_type` INT DEFAULT NULL COMMENT '源对象类型:2-设备,3-系统',
  993. `source_obj_code` VARCHAR(64) DEFAULT NULL COMMENT '源对象代码',
  994. `source_model_code` VARCHAR(64) DEFAULT NULL COMMENT '源对象模型代码',
  995. `event_key` VARCHAR(128) DEFAULT NULL COMMENT '事件标识',
  996. `attr_key` VARCHAR(128) DEFAULT NULL COMMENT '属性标识',
  997. `condition_expr` TEXT DEFAULT NULL COMMENT '条件表达式(JSON)',
  998. `enable` INT DEFAULT 1 COMMENT '是否启用',
  999. `priority` INT DEFAULT 50 COMMENT '优先级',
  1000. `create_time` DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1001. `update_time` DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  1002. PRIMARY KEY (`id`),
  1003. KEY `idx_strategy_code` (`strategy_code`),
  1004. KEY `idx_source_obj` (`source_obj_code`),
  1005. KEY `idx_event_key` (`event_key`)
  1006. ) ENGINE=INNODB AUTO_INCREMENT=1 COMMENT='策略触发条件表';
  1007. -- ----------------------------
  1008. -- 能源策略参数表
  1009. -- ----------------------------
  1010. drop table if exists adm_op_energy_strategy_param;
  1011. create table adm_op_energy_strategy_param (
  1012. `id` bigint(20) not null auto_increment comment '序号',
  1013. `strategy_code` varchar(64) not null comment '策略代码',
  1014. `param_group` varchar(128) not null comment '策略分组',
  1015. `param_key` varchar(128) not null comment '参数键值',
  1016. `param_name` varchar(256) not null comment '参数名称',
  1017. `param_value` varchar(1024) default null comment '参数值',
  1018. `param_value_format` varchar(128) default null comment '参数值格式',
  1019. `edit_enable` int default 0 comment '可编辑',
  1020. primary key (`id`),
  1021. unique key ux_op_energy_strategy_param(`strategy_code`, `param_group`, `param_key`)
  1022. ) engine=innodb auto_increment=1 comment = '能源策略参数表';
  1023. -- ----------------------------
  1024. -- 能源策略步骤
  1025. -- ----------------------------
  1026. drop table if exists adm_op_energy_strategy_step;
  1027. CREATE TABLE adm_op_energy_strategy_step (
  1028. `id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '序号',
  1029. `strategy_code` VARCHAR(64) NOT NULL COMMENT '策略代码',
  1030. `step_code` VARCHAR(32) NOT NULL COMMENT '步骤代码',
  1031. `step_name` VARCHAR(64) NOT NULL COMMENT '步骤名称',
  1032. `step_type` VARCHAR(32) NOT NULL COMMENT '步骤类型:ABILITY-能力调用,DELAY-延时,CONDITION-条件判断,PARALLEL-并行,LOOP-循环',
  1033. `step_index` INT NOT NULL COMMENT '步骤顺序',
  1034. `parent_step_code` VARCHAR(32) DEFAULT NULL COMMENT '父步骤代码(用于嵌套)',
  1035. `condition_expr` TEXT DEFAULT NULL COMMENT '执行条件(JSON表达式)',
  1036. `target_obj_type` INT DEFAULT NULL COMMENT '目标对象类型:2-设备,3-系统',
  1037. `target_obj_code` VARCHAR(64) DEFAULT NULL COMMENT '目标对象代码',
  1038. `target_model_code` VARCHAR(64) DEFAULT NULL COMMENT '目标模型代码',
  1039. `ability_key` VARCHAR(128) DEFAULT NULL COMMENT '能力标识',
  1040. `ability_param` TEXT DEFAULT NULL COMMENT '能力参数(JSON)',
  1041. `param_source` VARCHAR(32) DEFAULT 'STATIC' COMMENT '参数来源:STATIC-静态,CONTEXT-上下文,ATTR-属性值',
  1042. `param_mapping` TEXT DEFAULT NULL COMMENT '参数映射配置(JSON)',
  1043. `delay_seconds` INT DEFAULT 0 COMMENT '延时秒数',
  1044. `retry_on_fail` INT DEFAULT 0 COMMENT '失败是否重试',
  1045. `retry_times` INT DEFAULT 0 COMMENT '重试次数',
  1046. `retry_interval` INT DEFAULT 5 COMMENT '重试间隔(秒)',
  1047. `continue_on_fail` INT DEFAULT 0 COMMENT '失败是否继续',
  1048. `timeout` INT DEFAULT 60 COMMENT '超时时间(秒)',
  1049. `enable` INT DEFAULT 1 COMMENT '是否启用',
  1050. `remark` VARCHAR(256) DEFAULT NULL COMMENT '备注',
  1051. `loop_max_count` INT DEFAULT 0 COMMENT '最大循环次数(0=无限循环)',
  1052. `loop_interval` INT DEFAULT 1000 COMMENT '循环间隔(毫秒)',
  1053. `loop_condition` TEXT DEFAULT NULL COMMENT '循环跳出条件表达式',
  1054. `create_time` DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1055. `update_time` DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  1056. PRIMARY KEY (`id`),
  1057. UNIQUE KEY `ux_strategy_step` (`strategy_code`, `step_code`),
  1058. KEY `idx_step_index` (`strategy_code`, `step_index`),
  1059. KEY `idx_parent_step` (`parent_step_code`)
  1060. ) ENGINE=INNODB AUTO_INCREMENT=1 COMMENT='能源策略步骤表';
  1061. -- ----------------------------
  1062. -- 策略执行日志表
  1063. -- ----------------------------
  1064. drop table if exists adm_op_energy_strategy_exec_log;
  1065. CREATE TABLE adm_op_energy_strategy_exec_log (
  1066. `id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '序号',
  1067. `strategy_code` VARCHAR(64) NOT NULL COMMENT '策略代码',
  1068. `exec_id` VARCHAR(64) NOT NULL COMMENT '执行ID(UUID)',
  1069. `trigger_type` VARCHAR(32) DEFAULT NULL COMMENT '触发类型',
  1070. `trigger_source` VARCHAR(128) DEFAULT NULL COMMENT '触发源',
  1071. `exec_status` INT NOT NULL COMMENT '执行状态:0-执行中,1-成功,2-失败,3-超时',
  1072. `start_time` DATETIME NOT NULL COMMENT '开始时间',
  1073. `end_time` DATETIME DEFAULT NULL COMMENT '结束时间',
  1074. `duration` INT DEFAULT NULL COMMENT '执行时长(毫秒)',
  1075. `context_data` TEXT DEFAULT NULL COMMENT '执行上下文(JSON)',
  1076. `result_data` TEXT DEFAULT NULL COMMENT '执行结果(JSON)',
  1077. `error_message` TEXT DEFAULT NULL COMMENT '错误信息',
  1078. `exec_by` VARCHAR(64) DEFAULT NULL COMMENT '执行人',
  1079. `create_time` DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1080. PRIMARY KEY (`id`),
  1081. UNIQUE KEY `ux_exec_id` (`exec_id`),
  1082. KEY `idx_strategy_code` (`strategy_code`),
  1083. KEY `idx_start_time` (`start_time`),
  1084. KEY `idx_exec_status` (`exec_status`)
  1085. ) ENGINE=INNODB AUTO_INCREMENT=1 COMMENT='策略执行日志表';
  1086. -- ----------------------------
  1087. -- 策略步骤执行日志表
  1088. -- ----------------------------
  1089. drop table if exists adm_op_energy_strategy_step_log;
  1090. CREATE TABLE adm_op_energy_strategy_step_log (
  1091. `id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '序号',
  1092. `exec_id` VARCHAR(64) NOT NULL COMMENT '策略执行ID',
  1093. `strategy_code` VARCHAR(64) NOT NULL COMMENT '策略代码',
  1094. `step_code` VARCHAR(32) NOT NULL COMMENT '步骤代码',
  1095. `step_name` VARCHAR(64) NOT NULL COMMENT '步骤名称',
  1096. `step_index` INT NOT NULL COMMENT '步骤顺序',
  1097. `exec_status` INT NOT NULL COMMENT '执行状态:0-执行中,1-成功,2-失败,3-跳过',
  1098. `start_time` DATETIME NOT NULL COMMENT '开始时间',
  1099. `end_time` DATETIME DEFAULT NULL COMMENT '结束时间',
  1100. `duration` INT DEFAULT NULL COMMENT '执行时长(毫秒)',
  1101. `input_param` TEXT DEFAULT NULL COMMENT '输入参数',
  1102. `output_result` TEXT DEFAULT NULL COMMENT '输出结果',
  1103. `error_message` TEXT DEFAULT NULL COMMENT '错误信息',
  1104. `retry_count` INT DEFAULT 0 COMMENT '重试次数',
  1105. `create_time` DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1106. PRIMARY KEY (`id`),
  1107. KEY `idx_exec_id` (`exec_id`),
  1108. KEY `idx_strategy_step` (`strategy_code`, `step_code`)
  1109. ) ENGINE=INNODB AUTO_INCREMENT=1 COMMENT='策略步骤执行日志表';
  1110. -- ----------------------------
  1111. -- 碳核算账户配置表
  1112. -- ----------------------------
  1113. drop table if exists adm_ems_carbon_account_cfg;
  1114. create table adm_ems_carbon_account_cfg (
  1115. `id` bigint(20) not null auto_increment comment '序号',
  1116. `cfg_code` varchar(128) not null comment '配置代码',
  1117. `definition` varchar(32) not null comment '定义',
  1118. `emission_activity` varchar(32) not null comment '排放活动',
  1119. `emission_source` varchar(32) not null comment '排放源',
  1120. `gas_category` varchar(128) not null comment '气体类别',
  1121. `factor_value` double default null comment '排放因子',
  1122. `create_time` datetime default CURRENT_TIMESTAMP comment '创建时间',
  1123. `update_time` datetime default CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP comment '更新时间',
  1124. primary key (`id`)
  1125. ) engine=innodb auto_increment=1 comment = '碳核算账户配置表';
  1126. INSERT INTO `adm_ems_carbon_account_cfg` (`cfg_code`, `definition`, `emission_activity`, `emission_source`, `gas_category`, `factor_value`) VALUES ('direct.gas.statCombustion', '直接温室气体排放', '固定源化石燃料燃烧排放', '柴油发电机', 'CO₂', null);
  1127. INSERT INTO `adm_ems_carbon_account_cfg` (`cfg_code`, `definition`, `emission_activity`, `emission_source`, `gas_category`, `factor_value`) VALUES ('direct.gas.movCombustion', '直接温室气体排放', '移动源化石燃料燃烧排放', '柴油发电机', 'CH₄,N₂O', null);
  1128. INSERT INTO `adm_ems_carbon_account_cfg` (`cfg_code`, `definition`, `emission_activity`, `emission_source`, `gas_category`, `factor_value`) VALUES ('indirect.gas.electricity', '间接温室气体排放', '外购电力生产消耗排放', '外购电力使用', 'CO₂', null);
  1129. -- ----------------------------
  1130. -- 能源设施告警表策略表
  1131. -- ----------------------------
  1132. drop table if exists adm_op_alarm_policy;
  1133. create table adm_op_alarm_policy (
  1134. `id` bigint(20) not null auto_increment comment '序号',
  1135. `area_code` varchar(32) not null comment '园区代码',
  1136. `policy_code` varchar(16) not null comment '策略代码',
  1137. `policy_name` varchar(32) not null comment '策略名称',
  1138. `alarm_obj_type` int not null comment '告警对象类型',
  1139. `alarm_obj_index` varchar(64) not null comment '告警对象指标',
  1140. `alarm_rule_type` int default null comment '告警规则 1:大于 2:小于',
  1141. `alarm_threshold_value` double default null comment '告警阈值',
  1142. `alarm_code` varchar(64) default null comment '告警代码',
  1143. `alarm_msg` varchar(200) default null comment '告警描述',
  1144. `alarm_type` int default null comment '告警类型 1:一般告警 2:重要告警 3:紧急告警 4:恢复告警 5:诊断告警 6:其他告警',
  1145. primary key (`id`)
  1146. ) engine=innodb auto_increment=1 comment = '能源设施告警表策略表';
  1147. -- ----------------------------
  1148. -- 能源设施告警表
  1149. -- ----------------------------
  1150. drop table if exists adm_op_alarm;
  1151. create table adm_op_alarm (
  1152. `id` bigint(20) not null auto_increment comment '序号',
  1153. `area_code` varchar(32) not null comment '园区代码',
  1154. `system_code` varchar(16) default null comment '子系统代码',
  1155. `obj_type` int not null comment '对象类型 0:园区,1:区块,2:设施,3:设备',
  1156. `obj_code` varchar(32) not null comment '对象代码',
  1157. `obj_name` varchar(128) default null comment '对象名称',
  1158. `alarm_date` date default null comment '告警日期',
  1159. `alarm_time` datetime default null comment '告警时间',
  1160. `alarm_code` varchar(64) default null comment '告警代码',
  1161. `alarm_msg` varchar(64) default null comment '告警描述',
  1162. `alarm_type` int default null comment '告警类型 1:一般告警 2:重要告警 3:紧急告警 4:恢复告警 5:诊断告警 6:其他告警',
  1163. `alarm_state` int default null comment '告警状态 0-新增,1-处置中,2-已处置,3-消散',
  1164. primary key (`id`),
  1165. key inx_op_alarm_date(`alarm_date`)
  1166. ) engine=innodb auto_increment=1 comment = '能源设施告警表';
  1167. -- 1. 巡检计划表(支持手动/自动巡检)
  1168. DROP TABLE IF EXISTS adm_op_inspection_plan;
  1169. CREATE TABLE adm_op_inspection_plan (
  1170. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '序号',
  1171. `area_code` varchar(32) NOT NULL COMMENT '归属区域代码',
  1172. `plan_code` varchar(64) NOT NULL COMMENT '计划代码',
  1173. `plan_name` varchar(64) NOT NULL COMMENT '计划名称',
  1174. `plan_type` tinyint NOT NULL DEFAULT 1 COMMENT '计划类型 1:手动巡检 2:自动巡检',
  1175. `plan_status` tinyint NOT NULL DEFAULT 0 COMMENT '计划状态 0:待执行 1:执行中 2:已完成 3:已取消',
  1176. `target_type` tinyint NOT NULL COMMENT '巡检目标类型 0:区域 1:设施 2:设备',
  1177. `target_codes` text DEFAULT NULL COMMENT '巡检目标代码(JSON数组)',
  1178. `target_names` varchar(512) DEFAULT NULL COMMENT '巡检目标名称(逗号分隔,用于展示)',
  1179. `cron_expression` varchar(64) DEFAULT NULL COMMENT 'Cron表达式(自动巡检用)',
  1180. `schedule_enabled` tinyint DEFAULT 0 COMMENT '是否启用调度 0:禁用 1:启用',
  1181. `last_exec_time` datetime DEFAULT NULL COMMENT '上次执行时间',
  1182. `next_exec_time` datetime DEFAULT NULL COMMENT '下次执行时间',
  1183. `exec_count` int DEFAULT 0 COMMENT '累计执行次数',
  1184. `plan_time` datetime DEFAULT NULL COMMENT '计划执行时间',
  1185. `executor` varchar(32) DEFAULT NULL COMMENT '执行人(手动巡检)',
  1186. `description` varchar(256) DEFAULT NULL COMMENT '计划描述',
  1187. `create_by` varchar(64) DEFAULT NULL COMMENT '创建者',
  1188. `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1189. `update_by` varchar(64) DEFAULT NULL COMMENT '更新者',
  1190. `update_time` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  1191. PRIMARY KEY (`id`),
  1192. UNIQUE KEY `ux_plan_code` (`plan_code`),
  1193. KEY `idx_area_code` (`area_code`),
  1194. KEY `idx_plan_status` (`plan_status`)
  1195. ) ENGINE=InnoDB AUTO_INCREMENT=1 COMMENT='巡检计划表';
  1196. -- 2. 巡检规则表(自动巡检的检查规则配置)
  1197. DROP TABLE IF EXISTS adm_op_inspection_rule;
  1198. CREATE TABLE adm_op_inspection_rule (
  1199. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '序号',
  1200. `plan_code` varchar(64) NOT NULL COMMENT '计划代码',
  1201. `rule_code` varchar(64) NOT NULL COMMENT '规则代码',
  1202. `rule_name` varchar(64) NOT NULL COMMENT '规则名称',
  1203. `device_model` varchar(64) DEFAULT NULL COMMENT '设备模型代码(可选,不填则应用于所有设备)',
  1204. `attr_key` varchar(128) NOT NULL COMMENT '属性标识',
  1205. `attr_name` varchar(256) DEFAULT NULL COMMENT '属性名称',
  1206. `check_type` tinyint NOT NULL DEFAULT 1 COMMENT '检查类型 1:范围检查 2:等值检查 3:非空检查 4:在线状态',
  1207. `min_value` varchar(64) DEFAULT NULL COMMENT '最小值(范围检查用)',
  1208. `max_value` varchar(64) DEFAULT NULL COMMENT '最大值(范围检查用)',
  1209. `expect_value` varchar(64) DEFAULT NULL COMMENT '期望值(等值检查用)',
  1210. `rule_order` int DEFAULT 0 COMMENT '规则顺序',
  1211. `enabled` tinyint DEFAULT 1 COMMENT '是否启用 0:禁用 1:启用',
  1212. `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1213. `update_time` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  1214. PRIMARY KEY (`id`),
  1215. UNIQUE KEY `ux_rule_code` (`rule_code`),
  1216. KEY `idx_plan_code` (`plan_code`)
  1217. ) ENGINE=InnoDB AUTO_INCREMENT=1 COMMENT='巡检规则表';
  1218. -- 3. 巡检报告表
  1219. DROP TABLE IF EXISTS adm_op_inspection_report;
  1220. CREATE TABLE adm_op_inspection_report (
  1221. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '序号',
  1222. `report_code` varchar(64) NOT NULL COMMENT '报告代码',
  1223. `plan_code` varchar(64) NOT NULL COMMENT '计划代码',
  1224. `plan_name` varchar(64) DEFAULT NULL COMMENT '计划名称',
  1225. `plan_type` tinyint DEFAULT NULL COMMENT '计划类型 1:手动巡检 2:自动巡检',
  1226. `area_code` varchar(32) DEFAULT NULL COMMENT '归属区域代码',
  1227. `area_name` varchar(64) DEFAULT NULL COMMENT '归属区域名称',
  1228. `target_type` tinyint DEFAULT NULL COMMENT '巡检目标类型',
  1229. `execute_time` datetime DEFAULT NULL COMMENT '执行时间',
  1230. `finish_time` datetime DEFAULT NULL COMMENT '完成时间',
  1231. `executor` varchar(32) DEFAULT NULL COMMENT '执行人',
  1232. `result_status` tinyint NOT NULL DEFAULT 0 COMMENT '结果状态 0:正常 1:异常 2:部分异常',
  1233. `total_count` int DEFAULT 0 COMMENT '检查总数',
  1234. `normal_count` int DEFAULT 0 COMMENT '正常数量',
  1235. `abnormal_count` int DEFAULT 0 COMMENT '异常数量',
  1236. `result_summary` text DEFAULT NULL COMMENT '结果摘要(JSON)',
  1237. `manual_remark` text DEFAULT NULL COMMENT '手动备注(富文本,手动巡检用)',
  1238. `create_by` varchar(64) DEFAULT NULL COMMENT '创建人',
  1239. `update_by` varchar(64) DEFAULT NULL COMMENT '修改人',
  1240. `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1241. `update_time` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  1242. PRIMARY KEY (`id`),
  1243. UNIQUE KEY `ux_report_code` (`report_code`),
  1244. KEY `idx_plan_code` (`plan_code`),
  1245. KEY `idx_execute_time` (`execute_time`)
  1246. ) ENGINE=InnoDB AUTO_INCREMENT=1 COMMENT='巡检报告表';
  1247. -- 4. 巡检报告明细表(记录每个设备的检查结果)
  1248. DROP TABLE IF EXISTS adm_op_inspection_report_detail;
  1249. CREATE TABLE adm_op_inspection_report_detail (
  1250. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '序号',
  1251. `report_code` varchar(64) NOT NULL COMMENT '报告代码',
  1252. `device_code` varchar(64) NOT NULL COMMENT '设备代码',
  1253. `device_name` varchar(64) DEFAULT NULL COMMENT '设备名称',
  1254. `device_model` varchar(64) DEFAULT NULL COMMENT '设备模型',
  1255. `device_model_name` varchar(128) DEFAULT NULL COMMENT '设备模型名称',
  1256. `location` varchar(200) DEFAULT NULL COMMENT '设备位置',
  1257. `area_path` varchar(512) DEFAULT NULL COMMENT '区域路径',
  1258. `result_status` tinyint NOT NULL DEFAULT 0 COMMENT '结果状态 0:正常 1:异常',
  1259. `check_items` text DEFAULT NULL COMMENT '检查项结果(JSON数组)',
  1260. `check_time` datetime DEFAULT NULL COMMENT '检查时间',
  1261. `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1262. PRIMARY KEY (`id`),
  1263. KEY `idx_report_code` (`report_code`),
  1264. KEY `idx_device_code` (`device_code`)
  1265. ) ENGINE=InnoDB AUTO_INCREMENT=1 COMMENT='巡检报告明细表';
  1266. ('IP202501300002', 'IR004', 'CO2浓度检查', 'M_Z020_DEV_BA_XF', 'ppm', 'CO2浓度', 1, '0', '1000', NULL, 4, 1);
  1267. -- ----------------------------
  1268. -- 设备台账表
  1269. -- ----------------------------
  1270. drop table if exists adm_ems_device_ledger;
  1271. create table adm_ems_device_ledger (
  1272. `id` bigint(20) not null auto_increment comment '序号',
  1273. `record_code` varchar(32) not null comment '记录编号',
  1274. `area_code` varchar(32) not null comment '园区代码',
  1275. `obj_type` int not null comment '对象类型 1:区域 2:设施 3:设备',
  1276. `obj_code` varchar(64) not null comment '对象代码',
  1277. `obj_name` varchar(64) default null comment '对象名称',
  1278. `record_time` timestamp not null comment '日期 yyyy-MM-dd HH:mm:ss',
  1279. `ins_location` varchar(128) default null comment '安装位置',
  1280. `maintain_title` varchar(128) not null comment '维护标题',
  1281. `maintain_content` text default null comment '维护内容',
  1282. `maintain_person` varchar(32) default null comment '维护人',
  1283. `create_time` datetime default CURRENT_TIMESTAMP comment '创建时间',
  1284. `update_time` datetime default CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP comment '更新时间',
  1285. primary key (`id`),
  1286. key inx_ems_device_rbook(`record_code`)
  1287. ) engine=innodb auto_increment=1 comment = '设备台账表';
  1288. -- ----------------------------
  1289. -- 对象&标签关系表
  1290. -- ----------------------------
  1291. drop table if exists adm_obj_tag_rel;
  1292. create table adm_obj_tag_rel (
  1293. `tag_code` varchar(64) not null comment '标签代码',
  1294. `obj_type` int not null comment '对象类型 1:区域,2:设施,3:设备',
  1295. `obj_code` varchar(64) not null comment '对象代码',
  1296. unique key inx_obj_tag_rel(`tag_code`, `obj_type`, `obj_code`)
  1297. ) engine=innodb auto_increment=1 comment = '对象&标签关系表';
  1298. -- ----------------------------
  1299. -- 抄表记录表
  1300. -- ----------------------------
  1301. drop table if exists adm_meter_reading;
  1302. create table adm_meter_reading (
  1303. `id` bigint(20) not null auto_increment comment '序号',
  1304. `device_code` varchar(64) not null comment '计量设备code',
  1305. `area_code` varchar(32) not null comment '服务区代码',
  1306. `year` varchar(4) not null comment '年份yyyy',
  1307. `meter_month` varchar(6) not null comment '计量月yyyyMM',
  1308. `last_reading` int default null comment '上次示数',
  1309. `last_time` date default null comment '上次抄表日期',
  1310. `meter_reading` int not null comment '抄表值',
  1311. `meter_time` date not null comment '本次抄表日期',
  1312. `increase` int not null comment '增量',
  1313. `create_time` datetime default CURRENT_TIMESTAMP comment '创建时间',
  1314. `update_time` datetime default CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP comment '更新时间',
  1315. primary key (`id`),
  1316. key meter_reading_manual(`device_code`)
  1317. ) engine=innodb auto_increment=1 comment = '抄表记录表';
  1318. -- ----------------------------
  1319. -- 服务区用电属性表
  1320. -- ----------------------------
  1321. drop table if exists adm_area_elec_attr;
  1322. create table adm_area_elec_attr (
  1323. `id` bigint(20) not null auto_increment comment '序号',
  1324. `area_code` varchar(32) not null comment '园区代码',
  1325. `price_code` varchar(16) not null comment '价格编码',
  1326. `req_capacity_flag` int default 0 comment '容(需)量标识',
  1327. `trans_capacity` double default null comment '变压器容量(千伏安·月)',
  1328. `req_quantity` double default null comment '最大需量(千瓦·月)',
  1329. `create_time` datetime default CURRENT_TIMESTAMP comment '创建时间',
  1330. `update_time` datetime default CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP comment '更新时间',
  1331. primary key (`id`),
  1332. unique key ux_area_elec_attr(`area_code`)
  1333. ) engine=innodb auto_increment=1 comment = '服务区用电属性表';
  1334. -- ----------------------------
  1335. -- 国网电价配置表
  1336. -- ----------------------------
  1337. drop table if exists adm_gw_elecprice_config;
  1338. create table adm_gw_elecprice_config (
  1339. `id` bigint(20) not null auto_increment comment '序号',
  1340. `cfg_code` varchar(4) not null comment '配置代码',
  1341. `elec_type` int not null comment '用电分类 1-居民 2-农业 3-工业单一制 4-工业两部制',
  1342. `voltage_level` varchar(32) not null comment '电压等级',
  1343. `op_price` double not null comment '平时段电价',
  1344. `cp_price` double default null comment '尖峰时段电价',
  1345. `p_price` double default null comment '峰时段电价',
  1346. `v_price` double default null comment '谷时段电价',
  1347. `dv_price` double default null comment '深谷时段电价',
  1348. `max_req_price` double default null comment '最大需量用电价格',
  1349. `trans_capacity_price` double default null comment '变压器容量用电价格',
  1350. primary key (`id`),
  1351. unique key ux_gw_elecprice_config(`cfg_code`)
  1352. ) engine=innodb auto_increment=1 comment = '电价配置表';
  1353. -- ----------------------------
  1354. -- 非电能源价格配置表
  1355. -- ----------------------------
  1356. drop table if exists adm_fd_energyprice_config;
  1357. create table adm_fd_energyprice_config (
  1358. `id` bigint(20) not null auto_increment comment '序号',
  1359. `cfg_code` varchar(4) not null comment '配置代码',
  1360. `area_code` varchar(32) default null comment '园区代码',
  1361. `meter_cls` int not null comment '计量介质',
  1362. `unit_price` double not null comment '单位价格',
  1363. `meter_unit` varchar(32) default null comment '计量单位',
  1364. primary key (`id`),
  1365. unique key ux_fd_energyprice_config(`cfg_code`)
  1366. ) engine=innodb auto_increment=1 comment = '非电能源价格配置表';
  1367. -- ----------------------------
  1368. -- 光伏电价配置表
  1369. -- ----------------------------
  1370. drop table if exists adm_pv_elecprice_config;
  1371. create table adm_pv_elecprice_config (
  1372. `id` bigint(20) not null auto_increment comment '序号',
  1373. `cfg_code` varchar(16) not null comment '配置代码',
  1374. `price_name` varchar(32) not null comment '价格名称',
  1375. `obj_price` double default null comment '对象价格',
  1376. `state_subsidy` double default null comment '国家补贴',
  1377. `local_subsidy` double default null comment '地方补贴',
  1378. primary key (`id`),
  1379. unique key ux_pv_elecprice_config(`cfg_code`)
  1380. ) engine=innodb auto_increment=1 comment = '光伏电价配置表';
  1381. INSERT INTO `adm_pv_elecprice_config` (`cfg_code`, `price_name`, `obj_price`, `state_subsidy`, `local_subsidy`) VALUES ('0000', '默认价格', 0.88, 0.42, 0.3);
  1382. -- ----------------------------
  1383. -- 电价策略表
  1384. -- ----------------------------
  1385. drop table if exists adm_elecprice_strategy;
  1386. create table adm_elecprice_strategy (
  1387. `id` bigint(20) not null auto_increment comment '序号',
  1388. `strategy_code` varchar(32) not null comment '策略代码',
  1389. `strategy_name` varchar(16) not null comment '策略名称',
  1390. `strategy_desc` varchar(128) default null comment '策略描述',
  1391. `support_type` varchar(128) default null comment '支持小时电价类型',
  1392. `exec_month` varchar(128) default null comment '执行月份',
  1393. `exec_date_type` int default null comment '执行日期类型',
  1394. `exec_date` varchar(128) default null comment '执行日期',
  1395. `priority` int default 0 comment '优先级',
  1396. `edit_flag` int default 1 comment '编辑标识',
  1397. `create_time` datetime default CURRENT_TIMESTAMP comment '创建时间',
  1398. `update_time` datetime default CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP comment '更新时间',
  1399. primary key (`id`),
  1400. unique key ux_elecprice_strategy(`strategy_code`)
  1401. ) engine=innodb auto_increment=1 comment = '电价策略表';
  1402. -- ----------------------------
  1403. -- 电价策略小时表
  1404. -- ----------------------------
  1405. drop table if exists adm_elecprice_strategy_hour;
  1406. create table adm_elecprice_strategy_hour (
  1407. `id` bigint(20) not null auto_increment comment '序号',
  1408. `strategy_code` varchar(16) not null comment '策略代码',
  1409. `start_time` time not null comment '开始时间',
  1410. `end_time` time not null comment '结束时间',
  1411. `type` int not null comment '计量类型',
  1412. primary key (`id`)
  1413. ) engine=innodb auto_increment=1 comment = '电价策略小时表';
  1414. -- ----------------------------
  1415. -- 商户能源计费配置
  1416. -- ----------------------------
  1417. drop table if exists adm_co_charging_config;
  1418. create table adm_co_charging_config (
  1419. `id` bigint(20) not null auto_increment comment '序号',
  1420. `area_code` varchar(32) not null comment '服务区代码',
  1421. `elec_unit_price` double not null comment '电计量单价 1度',
  1422. `elec_gt_compute_type` int not null comment '电公摊计算类型',
  1423. `elec_compute_desc` varchar(200) default null comment '电费计算说明',
  1424. `water_unit_price` double not null comment '水计量单价 1吨',
  1425. `water_gt_compute_type` int not null comment '水公摊计算类型',
  1426. `water_compute_desc` varchar(200) default null comment '水费计算说明',
  1427. primary key (`id`),
  1428. unique key ux_co_charging_config(`area_code`)
  1429. ) engine=innodb auto_increment=1 comment = '商户能源计费配置';
  1430. -- ----------------------------
  1431. -- 电网供应计量表
  1432. -- ----------------------------
  1433. drop table if exists adm_ems_pg_supply_h;
  1434. create table adm_ems_pg_supply_h (
  1435. `id` bigint(20) not null auto_increment comment '序号',
  1436. `area_code` varchar(32) not null comment '园区代码',
  1437. `facs_code` varchar(16) not null comment '设施代码',
  1438. `record_time` timestamp not null comment '记录时间',
  1439. `date` date not null comment '日期 yyyy-MM-dd',
  1440. `time` time not null comment '时间 HH:mm:ss',
  1441. `time_index` int not null comment '时间序列',
  1442. `meter_type` int default null comment '计量类型 -1:低谷电 0:平峰电 1:高峰电 2:尖峰电',
  1443. `meter_unit_price` double default null comment '单位电价(1度电)',
  1444. `use_elec_quantity` double default null comment '用电量 单位:kW-h(千瓦时)',
  1445. `use_elec_cost` double default null comment '用电电费 单位: ¥(元)',
  1446. `create_time` datetime default CURRENT_TIMESTAMP comment '创建时间',
  1447. primary key (`id`),
  1448. unique key ux_ems_pg_supply_h(`area_code`, `facs_code`, `date`, `time`),
  1449. key ix_ems_pg_supply_h_rt(`area_code`, `record_time`)
  1450. ) engine=innodb auto_increment=1 comment = '电网供应计量表-小时';
  1451. -- ----------------------------
  1452. -- 光伏并网计量表
  1453. -- ----------------------------
  1454. drop table if exists adm_ems_pv_supply_h;
  1455. create table adm_ems_pv_supply_h (
  1456. `id` bigint(20) not null auto_increment comment '序号',
  1457. `area_code` varchar(32) not null comment '园区代码',
  1458. `facs_code` varchar(16) not null comment '设施代码',
  1459. `record_time` timestamp not null comment '记录时间',
  1460. `date` date not null comment '日期 yyyy-MM-dd',
  1461. `time` time not null comment '时间 HH:mm:ss',
  1462. `time_index` int not null comment '时间序列',
  1463. `up_unit_price` double default null comment '单位电价(1度电)',
  1464. `gen_elec_quantity` double default null comment '发电量 单位:kW-h(千瓦时)',
  1465. `use_elec_quantity` double default null comment '自用电量 单位:kW-h(千瓦时)',
  1466. `up_elec_quantity` double default null comment '上网电量 单位:kW-h(千瓦时)',
  1467. `up_elec_earn` double default null comment '上网收益 单位: ¥(元)',
  1468. `create_time` datetime default CURRENT_TIMESTAMP comment '创建时间',
  1469. primary key (`id`),
  1470. unique key ux_ems_pg_supply_h(`area_code`, `facs_code`, `date`, `time`),
  1471. key ix_ems_pv_supply_h_rt(`area_code`, `record_time`)
  1472. ) engine=innodb auto_increment=1 comment = '光伏并网计量表光伏并网计量表-小时';
  1473. -- ----------------------------
  1474. -- 储能计量表
  1475. -- ----------------------------
  1476. drop table if exists adm_ems_elec_store_h;
  1477. create table adm_ems_elec_store_h (
  1478. `id` bigint(20) not null auto_increment comment '序号',
  1479. `area_code` varchar(32) not null comment '园区代码',
  1480. `facs_code` varchar(16) not null comment '设施代码',
  1481. `record_time` timestamp not null comment '记录时间',
  1482. `date` date not null comment '日期 yyyy-MM-dd',
  1483. `time` time not null comment '时间 HH:mm:ss',
  1484. `time_index` int not null comment '时间序列',
  1485. `charge_elec_quantity` double default null comment '充电电量 单位:kW-h(千瓦时)',
  1486. `discharge_elec_quantity` double default null comment '放电电量 单位:kW-h(千瓦时)',
  1487. `create_time` datetime default CURRENT_TIMESTAMP comment '创建时间',
  1488. primary key (`id`),
  1489. unique key ux_ems_elec_store_h(`area_code`, `facs_code`, `date`, `time`),
  1490. key ix_ems_elec_store_h_rt(`area_code`, `record_time`)
  1491. ) engine=innodb auto_increment=1 comment = '储能计量表-小时';
  1492. -- ----------------------------
  1493. -- 用电计量表-小时
  1494. -- ----------------------------
  1495. drop table if exists adm_elec_meter_h;
  1496. create table adm_elec_meter_h (
  1497. `id` bigint(20) not null auto_increment comment '序号',
  1498. `area_code` varchar(32) not null comment '园区代码',
  1499. `device_code` varchar(16) not null comment '计量设备',
  1500. `record_time` timestamp not null comment '记录时间',
  1501. `date` date not null comment '日期 yyyy-MM-dd',
  1502. `time` time not null comment '时间 HH:mm:ss',
  1503. `time_index` int not null comment '时间序列',
  1504. `elec_quantity` double default null comment '用电量 单位:kW-h(千瓦时)',
  1505. `meter_type` int default null comment '计量类型 -1:低谷电 0:平峰电 1:高峰电 2:尖峰电',
  1506. `meter_unit_price` double default null comment '单位电价(1度电)',
  1507. `use_elec_cost` double default null comment '小时电费',
  1508. `meter_reading` double default null comment '抄表示数',
  1509. `create_time` datetime default CURRENT_TIMESTAMP comment '创建时间',
  1510. primary key (`id`),
  1511. unique key ux_elec_meter_h(`device_code`, `record_time`)
  1512. ) engine=innodb auto_increment=1 comment = '用电计量表-小时';
  1513. -- ----------------------------
  1514. -- 用水计量表-小时
  1515. -- ----------------------------
  1516. drop table if exists adm_water_meter_h;
  1517. create table adm_water_meter_h (
  1518. `id` bigint(20) not null auto_increment comment '序号',
  1519. `area_code` varchar(32) not null comment '园区代码',
  1520. `device_code` varchar(16) not null comment '计量设备',
  1521. `record_time` timestamp not null comment '记录时间',
  1522. `date` date not null comment '日期 yyyy-MM-dd',
  1523. `time` time not null comment '时间 HH:mm:ss',
  1524. `time_index` int not null comment '时间序列',
  1525. `water_quantity` double default null comment '用水量 单位:t(吨)',
  1526. `meter_unit_price` double default null comment '单位水价(1吨水)',
  1527. `use_water_cost` double default null comment '小时水费',
  1528. `meter_reading` double default null comment '抄表示数',
  1529. `create_time` datetime default CURRENT_TIMESTAMP comment '创建时间',
  1530. primary key (`id`),
  1531. unique key ux_water_meter_h(`device_code`, `record_time`)
  1532. ) engine=innodb auto_increment=1 comment = '用水计量表-小时';
  1533. -- ----------------------------
  1534. -- 电能计量日表
  1535. -- ----------------------------
  1536. drop table if exists adm_ems_elec_meter_d;
  1537. create table adm_ems_elec_meter_d (
  1538. `id` bigint(20) not null auto_increment comment '序号',
  1539. `area_code` varchar(32) not null comment '园区代码',
  1540. `date` date not null comment '日期 yyyy-MM-dd',
  1541. `total_use_quantity` double default null comment '总用电量 单位:kW-h(千瓦时)',
  1542. `pg_quantity` double default null comment '电网供应电量 单位:kW-h(千瓦时)',
  1543. `pv_gen_quantity` double default null comment '光伏发电电量 单位:kW-h(千瓦时)',
  1544. `pv_online_quantity` double default null comment '光伏上网电量 单位:kW-h(千瓦时)',
  1545. `pv_oneself_quantity` double default null comment '光伏自用电量 单位:kW-h(千瓦时)',
  1546. `pg_cost` double default null comment '电网电量花费 单位:¥(元)',
  1547. `pv_online_earn` double default null comment '光伏上网营收 单位:¥(元)',
  1548. `pv_oneself_save_cost` double default null comment '光伏自用节省支出 单位:¥(元)',
  1549. primary key (`id`),
  1550. unique key ux_ems_elec_meter_d(`area_code`, `date`)
  1551. ) engine=innodb auto_increment=1 comment = '电能计量日表';
  1552. -- ----------------------------
  1553. -- 节能计量日表
  1554. -- ----------------------------
  1555. drop table if exists adm_ems_eco_d;
  1556. create table adm_ems_eco_d (
  1557. `id` bigint(20) not null auto_increment comment '序号',
  1558. `area_code` varchar(32) not null comment '园区代码',
  1559. `date` date not null comment '日期 yyyy-MM-dd',
  1560. `elec_eco_quantity` double default null comment '节电量 单位:kW-h(千瓦时)',
  1561. `elec_eco_cost` double default null comment '节电金额 单位:元',
  1562. `water_eco_quantity` double default null comment '节水量 单位:t(吨)',
  1563. `water_eco_cost` double default null comment '节水金额 单位:元',
  1564. primary key (`id`),
  1565. unique key ux_ems_eco_d(`area_code`, `date`)
  1566. ) engine=innodb auto_increment=1 comment = '节能计量日表';
  1567. -- ----------------------------
  1568. -- 碳计量日表
  1569. -- ----------------------------
  1570. drop table if exists adm_ems_ca_meter_d;
  1571. create table adm_ems_ca_meter_d (
  1572. `id` bigint(20) not null auto_increment comment '序号',
  1573. `area_code` varchar(32) not null comment '园区代码',
  1574. `date` date not null comment '日期 yyyy-MM-dd',
  1575. `ca_emission_quantity` double default null comment '碳排放量 单位:单位:kg(千克)',
  1576. `ca_sink_quantity` double default null comment '碳汇量 单位:单位:kg(千克)',
  1577. primary key (`id`),
  1578. unique key ux_ems_elec_meter_d(`area_code`, `date`)
  1579. ) engine=innodb auto_increment=1 comment = '碳计量日表';
  1580. -- ----------------------------
  1581. -- 能源指标范围表
  1582. -- ----------------------------
  1583. drop table if exists adm_ems_index_range;
  1584. create table adm_ems_index_range (
  1585. `id` bigint(20) not null auto_increment comment '序号',
  1586. `obj_code` varchar(16) not null comment '对象代码',
  1587. `obj_type` int not null comment '对象类型',
  1588. `index_name` varchar(64) not null comment '指标名称',
  1589. `index_desc` varchar(200) default null comment '指标描述',
  1590. `index_upper_limit` double default null comment '指标上限',
  1591. `index_lower_limit` double default null comment '指标下限',
  1592. primary key (`id`),
  1593. key ux_ems_elec_pg_index(`obj_code`)
  1594. ) engine=innodb auto_increment=1 comment = '能源指标范围表';
  1595. -- ----------------------------
  1596. -- 储能设施指标表
  1597. -- ----------------------------
  1598. drop table if exists adm_ems_elec_store_index;
  1599. create table adm_ems_elec_store_index (
  1600. `id` bigint(20) not null auto_increment comment '序号',
  1601. `area_code` varchar(32) not null comment '园区代码',
  1602. `facs_code` varchar(16) not null comment '设施代码',
  1603. `device_code` varchar(64) not null comment '设备代码',
  1604. `date` date not null comment '日期 yyyy-MM-dd',
  1605. `time` datetime not null comment '时间 yyyy-MM-dd HH:mm:ss',
  1606. `charge_voltage` double default null comment '充电功率 单位:W(瓦)',
  1607. `discharge_power` double default null comment '放电功率 单位:W(瓦)',
  1608. `current_capacity` double default null comment '当前容量 单位:kW-h(千瓦·时)',
  1609. primary key (`id`),
  1610. unique key ux_ems_elec_store_index(`device_code`, `time`)
  1611. ) engine=innodb auto_increment=1 comment = '储能设施指标表';
  1612. -- ----------------------------
  1613. -- 充电交易记录主表
  1614. -- ----------------------------
  1615. DROP TABLE IF EXISTS adm_charging_transaction;
  1616. CREATE TABLE adm_charging_transaction (
  1617. `id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '序号',
  1618. `transaction_no` VARCHAR(32) NOT NULL COMMENT '交易流水号(BCD 16字节)',
  1619. `pile_code` VARCHAR(16) NOT NULL COMMENT '桩编码',
  1620. `gun_no` VARCHAR(4) NOT NULL COMMENT '枪号',
  1621. `device_code` VARCHAR(64) DEFAULT NULL COMMENT '关联充电枪设备编码',
  1622. `area_code` VARCHAR(32) DEFAULT NULL COMMENT '归属区域代码',
  1623. `start_time` DATETIME NOT NULL COMMENT '充电开始时间',
  1624. `end_time` DATETIME NOT NULL COMMENT '充电结束时间',
  1625. `charging_duration` INT DEFAULT NULL COMMENT '充电时长(分钟)',
  1626. `record_date` DATE NOT NULL COMMENT '记录日期(取结束时间的日期)',
  1627. `meter_start` DOUBLE DEFAULT NULL COMMENT '电表总起值(kWh, 4位小数)',
  1628. `meter_end` DOUBLE DEFAULT NULL COMMENT '电表总止值(kWh, 4位小数)',
  1629. `total_energy` DOUBLE DEFAULT 0 COMMENT '总电量(kWh)',
  1630. `total_energy_loss` DOUBLE DEFAULT 0 COMMENT '计损总电量(kWh)',
  1631. `total_amount` DOUBLE DEFAULT 0 COMMENT '总金额(元)',
  1632. `vin` VARCHAR(17) DEFAULT NULL COMMENT 'VIN码(ASCII 17字节)',
  1633. `transaction_type` TINYINT DEFAULT NULL COMMENT '交易类型(1:APP 2:刷卡 4:离线卡 5:VIN)',
  1634. `stop_reason` VARCHAR(4) DEFAULT NULL COMMENT '停止原因代码(Hex)',
  1635. `stop_reason_desc` VARCHAR(128) DEFAULT NULL COMMENT '停止原因描述',
  1636. `is_normal_stop` TINYINT DEFAULT 1 COMMENT '是否正常结束(0:异常 1:正常)',
  1637. `physical_card_no` VARCHAR(32) DEFAULT NULL COMMENT '物理卡号',
  1638. `include_in_ems` TINYINT DEFAULT 0 COMMENT '是否纳入能耗统计(0:否 1:是)',
  1639. `create_time` DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1640. `update_time` DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  1641. PRIMARY KEY (`id`),
  1642. UNIQUE KEY `uk_transaction_no` (`transaction_no`),
  1643. INDEX `idx_pile_gun` (`pile_code`, `gun_no`),
  1644. INDEX `idx_device_code` (`device_code`),
  1645. INDEX `idx_area_code` (`area_code`),
  1646. INDEX `idx_record_date` (`record_date`),
  1647. INDEX `idx_end_time` (`end_time`)
  1648. ) ENGINE=InnoDB AUTO_INCREMENT=1 COMMENT='充电交易记录主表';
  1649. -- ----------------------------
  1650. -- 充电计量表-按分时电价拆分
  1651. -- ----------------------------
  1652. DROP TABLE IF EXISTS adm_charging_meter_h;
  1653. CREATE TABLE adm_charging_meter_h (
  1654. `id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '序号',
  1655. `transaction_no` VARCHAR(32) NOT NULL COMMENT '关联交易流水号',
  1656. `area_code` VARCHAR(32) NOT NULL COMMENT '区域代码',
  1657. `device_code` VARCHAR(64) NOT NULL COMMENT '充电枪设备编码',
  1658. `record_time` TIMESTAMP NOT NULL COMMENT '记录时间(取交易结束时间)',
  1659. `date` DATE NOT NULL COMMENT '日期 yyyy-MM-dd',
  1660. `time` TIME NOT NULL COMMENT '时间 HH:mm:ss',
  1661. `elec_quantity` DOUBLE DEFAULT NULL COMMENT '电量(kWh)',
  1662. `elec_quantity_loss` DOUBLE DEFAULT NULL COMMENT '计损电量(kWh)',
  1663. `meter_type` INT DEFAULT NULL COMMENT '计量类型(-1:谷 0:平 1:峰 2:尖)',
  1664. `meter_unit_price` DOUBLE DEFAULT NULL COMMENT '单位电价(元/kWh, 充电桩上报)',
  1665. `use_elec_cost` DOUBLE DEFAULT NULL COMMENT '电费(元)',
  1666. `create_time` DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1667. PRIMARY KEY (`id`),
  1668. INDEX `idx_transaction_no` (`transaction_no`),
  1669. INDEX `idx_device_code` (`device_code`),
  1670. INDEX `idx_area_date` (`area_code`, `date`),
  1671. INDEX `idx_record_time` (`record_time`),
  1672. INDEX `idx_meter_type` (`meter_type`)
  1673. ) ENGINE=InnoDB AUTO_INCREMENT=1 COMMENT='充电计量表-分时';
  1674. -- ----------------------------
  1675. -- 电力产能预测表
  1676. -- ----------------------------
  1677. drop table if exists adm_ems_elec_prod_forecast;
  1678. create table adm_ems_elec_prod_forecast (
  1679. `id` bigint(20) not null auto_increment comment '序号',
  1680. `area_code` varchar(32) not null comment '园区代码',
  1681. `facs_code` varchar(16) not null comment '设施代码',
  1682. `date` date not null comment '日期 yyyy-MM-dd',
  1683. `elec_prod_quantity` double not null comment '发电量 单位:kW-h(千瓦·时)',
  1684. `up_elec_quantity` double default null comment 'sw 单位:kW-h(千瓦·时)',
  1685. `avg_power` double default null comment '功率 单位:kW(千瓦)',
  1686. primary key (`id`),
  1687. unique key ux_ems_elec_prod_forecast(`facs_code`, `date`)
  1688. ) engine=innodb auto_increment=1 comment = '电力产能预测表';
  1689. -- ----------------------------
  1690. -- 电力消耗预测表
  1691. -- ----------------------------
  1692. drop table if exists adm_ems_elec_consume_forecast;
  1693. create table adm_ems_elec_consume_forecast (
  1694. `id` bigint(20) not null auto_increment comment '序号',
  1695. `area_code` varchar(32) not null comment '园区代码',
  1696. `obj_code` varchar(32) not null comment '对象代码',
  1697. `obj_type` int not null comment '1-建筑 2-设施 3-设备',
  1698. `date` date not null comment '日期 yyyy-MM-dd',
  1699. `elec_use_quantity` double default null comment '用电量 (kW·h)',
  1700. primary key (`id`),
  1701. unique key ux_ems_elec_expend_forecast(`obj_code`, `date`)
  1702. ) engine=innodb auto_increment=1 comment = '电力消耗预测表';
  1703. -- ----------------------------
  1704. -- 碳排放预测表
  1705. -- ----------------------------
  1706. drop table if exists adm_ems_ca_emission_forecast;
  1707. create table adm_ems_ca_emission_forecast (
  1708. `id` bigint(20) not null auto_increment comment '序号',
  1709. `area_code` varchar(32) not null comment '园区代码',
  1710. `month` varchar(16) not null comment '日期 yyyy-MM',
  1711. `ca_emission` double default null comment '单位:kg(千克)',
  1712. primary key (`id`),
  1713. unique key ux_ems_ca_emission_forecast(`area_code`, `month`)
  1714. ) engine=innodb auto_increment=1 comment = '碳排放预测表';
  1715. -- ============================================================================
  1716. -- 报表数据源配置表 (主表) - 定义可查询的数据源
  1717. -- ============================================================================
  1718. DROP TABLE IF EXISTS `adm_report_datasource`;
  1719. CREATE TABLE `adm_report_datasource` (
  1720. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  1721. `ds_code` varchar(64) NOT NULL COMMENT '数据源编码(唯一标识)',
  1722. `ds_name` varchar(128) NOT NULL COMMENT '数据源名称',
  1723. `ds_desc` varchar(512) DEFAULT NULL COMMENT '数据源描述',
  1724. `main_table` varchar(128) NOT NULL COMMENT '主表名',
  1725. `main_alias` varchar(32) DEFAULT 't' COMMENT '主表别名',
  1726. `base_where` varchar(1024) DEFAULT NULL COMMENT '基础查询条件(固定条件)',
  1727. `default_order` varchar(256) DEFAULT NULL COMMENT '默认排序字段',
  1728. `category` varchar(64) DEFAULT NULL COMMENT '分类(prod-产能,elec-用电,water-用水,store-储能)',
  1729. `icon` varchar(64) DEFAULT NULL COMMENT '图标',
  1730. `sort_order` int DEFAULT 0 COMMENT '排序号',
  1731. `status` tinyint(1) DEFAULT 1 COMMENT '状态(0-禁用,1-启用)',
  1732. `remark` varchar(512) DEFAULT NULL COMMENT '备注',
  1733. `create_by` varchar(64) DEFAULT NULL COMMENT '创建者',
  1734. `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1735. `update_by` varchar(64) DEFAULT NULL COMMENT '更新者',
  1736. `update_time` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  1737. PRIMARY KEY (`id`),
  1738. UNIQUE KEY `uk_ds_code` (`ds_code`),
  1739. KEY `idx_category` (`category`),
  1740. KEY `idx_status` (`status`)
  1741. ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='自定义报表-数据源配置表';
  1742. -- ============================================================================
  1743. -- 报表字段配置表 - 定义数据源的可用字段
  1744. -- ============================================================================
  1745. DROP TABLE IF EXISTS `adm_report_field`;
  1746. CREATE TABLE `adm_report_field` (
  1747. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  1748. `ds_code` varchar(64) NOT NULL COMMENT '数据源编码',
  1749. `field_code` varchar(64) NOT NULL COMMENT '字段编码(对应数据库列名或别名)',
  1750. `field_name` varchar(128) NOT NULL COMMENT '字段显示名称',
  1751. `field_alias` varchar(64) DEFAULT NULL COMMENT '字段别名(用于SQL SELECT)',
  1752. `field_expr` varchar(512) DEFAULT NULL COMMENT '字段表达式(复杂计算字段)',
  1753. `field_type` varchar(32) NOT NULL COMMENT '字段类型(string/number/date/datetime/time)',
  1754. `field_format` varchar(64) DEFAULT NULL COMMENT '显示格式(如日期格式yyyy-MM-dd)',
  1755. `decimals` int DEFAULT 2 COMMENT '小数位数(数值类型)',
  1756. `unit` varchar(32) DEFAULT NULL COMMENT '单位(如kW·h、元、吨)',
  1757. `dict_type` varchar(64) DEFAULT NULL COMMENT '字典类型(用于值转换)',
  1758. `is_default` tinyint(1) DEFAULT 0 COMMENT '是否默认显示(0-否,1-是)',
  1759. `is_required` tinyint(1) DEFAULT 0 COMMENT '是否必选(0-否,1-是)',
  1760. `is_filterable` tinyint(1) DEFAULT 1 COMMENT '是否可筛选(0-否,1-是)',
  1761. `is_sortable` tinyint(1) DEFAULT 1 COMMENT '是否可排序(0-否,1-是)',
  1762. `is_aggregatable` tinyint(1) DEFAULT 0 COMMENT '是否可聚合统计(0-否,1-是)',
  1763. `aggregate_func` varchar(32) DEFAULT NULL COMMENT '默认聚合函数(SUM/AVG/MAX/MIN/COUNT)',
  1764. `group_name` varchar(64) DEFAULT NULL COMMENT '字段分组名称',
  1765. `width` int DEFAULT NULL COMMENT '列宽度(像素)',
  1766. `min_width` int DEFAULT 100 COMMENT '最小列宽度',
  1767. `sort_order` int DEFAULT 0 COMMENT '排序号',
  1768. `status` tinyint(1) DEFAULT 1 COMMENT '状态(0-禁用,1-启用)',
  1769. `remark` varchar(512) DEFAULT NULL COMMENT '备注',
  1770. `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1771. `update_time` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  1772. PRIMARY KEY (`id`),
  1773. UNIQUE KEY `uk_ds_field` (`ds_code`, `field_code`),
  1774. KEY `idx_ds_code` (`ds_code`),
  1775. KEY `idx_field_type` (`field_type`)
  1776. ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='自定义报表-字段配置表';
  1777. -- ============================================================================
  1778. -- 报表字段条件配置表 - 定义字段支持的查询条件
  1779. -- ============================================================================
  1780. DROP TABLE IF EXISTS `adm_report_field_condition`;
  1781. CREATE TABLE `adm_report_field_condition` (
  1782. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  1783. `ds_code` varchar(64) NOT NULL COMMENT '数据源编码',
  1784. `field_code` varchar(64) NOT NULL COMMENT '字段编码',
  1785. `condition_type` varchar(32) NOT NULL COMMENT '条件类型(eq/ne/gt/gte/lt/lte/like/in/between/isNull/isNotNull)',
  1786. `condition_name` varchar(64) NOT NULL COMMENT '条件显示名称',
  1787. `condition_symbol` varchar(16) DEFAULT NULL COMMENT '条件符号(=/>/>=/</<=/!=)',
  1788. `value_count` int DEFAULT 1 COMMENT '需要的值数量(1-单值,2-双值如between)',
  1789. `default_value` varchar(256) DEFAULT NULL COMMENT '默认值',
  1790. `is_default` tinyint(1) DEFAULT 0 COMMENT '是否默认条件',
  1791. `sort_order` int DEFAULT 0 COMMENT '排序号',
  1792. `status` tinyint(1) DEFAULT 1 COMMENT '状态',
  1793. PRIMARY KEY (`id`),
  1794. KEY `idx_ds_field` (`ds_code`, `field_code`)
  1795. ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='自定义报表-字段条件配置表';
  1796. -- ============================================================================
  1797. -- 报表关联关系配置表 - 定义表关联(用于code到name的转换等)
  1798. -- ============================================================================
  1799. DROP TABLE IF EXISTS `adm_report_relation`;
  1800. CREATE TABLE `adm_report_relation` (
  1801. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  1802. `ds_code` varchar(64) NOT NULL COMMENT '数据源编码',
  1803. `relation_code` varchar(64) NOT NULL COMMENT '关联编码',
  1804. `relation_name` varchar(128) DEFAULT NULL COMMENT '关联名称',
  1805. `join_type` varchar(16) DEFAULT 'LEFT' COMMENT '关联类型(LEFT/INNER/RIGHT)',
  1806. `join_table` varchar(128) NOT NULL COMMENT '关联表名',
  1807. `join_alias` varchar(32) NOT NULL COMMENT '关联表别名',
  1808. `join_condition` varchar(512) NOT NULL COMMENT '关联条件(如: t.area_code = a.area_code)',
  1809. `is_auto_join` tinyint(1) DEFAULT 1 COMMENT '是否自动关联(使用相关字段时自动JOIN)',
  1810. `sort_order` int DEFAULT 0 COMMENT '排序号',
  1811. `status` tinyint(1) DEFAULT 1 COMMENT '状态',
  1812. `remark` varchar(512) DEFAULT NULL COMMENT '备注',
  1813. PRIMARY KEY (`id`),
  1814. UNIQUE KEY `uk_ds_relation` (`ds_code`, `relation_code`),
  1815. KEY `idx_ds_code` (`ds_code`)
  1816. ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='自定义报表-关联关系配置表';
  1817. -- ============================================================================
  1818. -- 报表关联字段映射表 - 定义哪些字段需要哪个关联
  1819. -- ============================================================================
  1820. DROP TABLE IF EXISTS `adm_report_field_relation`;
  1821. CREATE TABLE `adm_report_field_relation` (
  1822. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  1823. `ds_code` varchar(64) NOT NULL COMMENT '数据源编码',
  1824. `field_code` varchar(64) NOT NULL COMMENT '字段编码',
  1825. `relation_code` varchar(64) NOT NULL COMMENT '关联编码',
  1826. PRIMARY KEY (`id`),
  1827. UNIQUE KEY `uk_field_relation` (`ds_code`, `field_code`, `relation_code`)
  1828. ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='自定义报表-字段关联映射表';
  1829. -- ============================================================================
  1830. -- 报表用户报表模板表 - 保存用户自定义的报表配置
  1831. -- ============================================================================
  1832. DROP TABLE IF EXISTS `adm_report_template`;
  1833. CREATE TABLE `adm_report_template` (
  1834. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  1835. `template_code` varchar(64) NOT NULL COMMENT '模板编码',
  1836. `template_name` varchar(128) NOT NULL COMMENT '模板名称',
  1837. `template_desc` varchar(512) DEFAULT NULL COMMENT '模板描述',
  1838. `ds_code` varchar(64) NOT NULL COMMENT '数据源编码',
  1839. `config_json` text NOT NULL COMMENT '配置JSON(包含字段、条件、排序等)',
  1840. `is_public` tinyint(1) DEFAULT 0 COMMENT '是否公开(0-私有,1-公开)',
  1841. `is_system` tinyint(1) DEFAULT 0 COMMENT '是否系统模板(0-否,1-是)',
  1842. `use_count` int DEFAULT 0 COMMENT '使用次数',
  1843. `user_id` bigint(20) DEFAULT NULL COMMENT '用户ID',
  1844. `user_name` varchar(64) DEFAULT NULL COMMENT '用户名',
  1845. `dept_id` bigint(20) DEFAULT NULL COMMENT '部门ID',
  1846. `status` tinyint(1) DEFAULT 1 COMMENT '状态',
  1847. `create_by` varchar(64) DEFAULT NULL COMMENT '创建者',
  1848. `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1849. `update_by` varchar(64) DEFAULT NULL COMMENT '更新者',
  1850. `update_time` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  1851. PRIMARY KEY (`id`),
  1852. UNIQUE KEY `uk_template_code` (`template_code`),
  1853. KEY `idx_ds_code` (`ds_code`),
  1854. KEY `idx_user_id` (`user_id`),
  1855. KEY `idx_is_public` (`is_public`)
  1856. ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='自定义报表-用户模板表';