| | |
| | | <?xml version="1.0" encoding="UTF-8" ?> |
| | | <!DOCTYPE mapper |
| | | PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" |
| | | "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> |
| | | <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> |
| | | <mapper namespace="com.lf.server.mapper.show.OneMapMapper"> |
| | | |
| | | <resultMap type="com.lf.server.entity.show.OneMapEntity" id="OneMapResult"> |
| | | <result property="value" column="value" /> |
| | | <result property="key" column="key" /> |
| | | <result property="value" column="value" /> |
| | | <result property="key" column="key" /> |
| | | </resultMap> |
| | | |
| | | |
| | | <!-- 项目类别 select * from bs.bs_project; --> |
| | | <select id="projectCategoryCount" resultType="java.util.Map"> |
| | | select projtype,count(*) from bs.bs_project group by projtype; |
| | | </select> |
| | | |
| | | |
| | | <!-- 项目位置分布 select a.*,st_astext(geom) from bs.bs_project a --> |
| | | <select id="projectLocationCount" resultType="java.util.Map"> |
| | |
| | | FROM lf.sys_dir c |
| | | WHERE c.name = a.name) || ')%') "sizes" |
| | | FROM lf.sys_dir a |
| | | WHERE name IN ('基础测绘', '基础地灾', '基础勘察', '合规数据', '管理数据', '测量(ESV)', '勘察(EGE)', '地灾(EGD)', '洞库(EGD)') |
| | | WHERE name IN ('基础测绘', '基础地灾', '基础勘察', '合规数据', '管理数据', '测绘(ESV)', '勘察(EGE)', '地灾(EGD)', '洞库(EGD)') |
| | | GROUP BY name |
| | | ORDER BY name; |
| | | </select> |
| | | |
| | | |
| | | <!-- 统计数据服务类型 --> |
| | | <select id="statisticalDataServiceType" resultType="java.util.Map"> |
| | | SELECT COUNT(*),TYPE FROM lf.sys_serve_log GROUP BY TYPE; |
| | | </select> |
| | | |
| | | <!-- 登录次数统计 --> |
| | | <!-- 登录次数统计 --> |
| | | <select id="loginNumberStatistics" resultType="java.util.Map"> |
| | | select b.uname, count(*) from lf.sys_login a inner join lf.sys_user b on a.userid = b.id group by uname; |
| | | </select> |
| | | |
| | | <!-- 数据统计 文件格式维度-文件个数 select type,count(*),count(sizes) from lf.sys_meta group by type; --> |
| | | <!-- 数据统计 文件格式维度-文件个数 select type,count(*),count(sizes) from lf.sys_meta group by type; --> |
| | | <select id="fileFormatCount" resultType="java.util.Map"> |
| | | select type,count(type) AS number,sum(sizes) AS capacity from lf.sys_meta group by type; |
| | | </select> |
| | | |
| | | <!-- 数据统计 数据申请 select * from lf.sys_apply a inner join lf.sys_user b on a.userid = b.id; --> |
| | | <!-- 数据统计 数据申请 select * from lf.sys_apply a inner join lf.sys_user b on a.userid = b.id; --> |
| | | <select id="dataApplyCount" resultType="java.util.Map"> |
| | | SELECT |
| | | count(c.name) AS number, |
| | |
| | | <select id="countProjectTour" resultType="java.util.Map"> |
| | | SELECT st_astext(geom) AS wkt,* FROM bs.m_pipeline |
| | | <where> |
| | | <if test="pipename != null and pipename != ''"> and pipename = #{pipename}</if> |
| | | <if test="pipename != null and pipename != ''"> |
| | | pipename = #{pipename} |
| | | </if> |
| | | </where> |
| | | </select> |
| | | |
| | |
| | | SELECT DISTINCT pipename FROM bs.m_pipeline; |
| | | </select> |
| | | |
| | | |
| | | <!-- 统计项目类型 1 --> |
| | | <!-- select (select string_agg(code, ',') from lf.sys_dir where name = a.name) "key", name "value" from lf.sys_dir a |
| | | where name in ('测量(ESV)', '勘察(EGE)', '地灾(EGD)', '洞库(EGD)') group by name order by name;--> |
| | | <!-- select (select string_agg(code, ',') from lf.sys_dir where name = a.name) "key", name "value" from lf.sys_dir a |
| | | where name in ('测绘(ESV)', '勘察(EGE)', '地灾(EGD)', '洞库(EGD)') group by name order by name;--> |
| | | <select id="selectProjectType1" resultMap="OneMapResult"> |
| | | SELECT |
| | | (SELECT string_agg(code, |
| | |
| | | select modular1,count(*) from lf.sys_operate group by modular1 order by modular1; |
| | | </select> |
| | | |
| | | |
| | | <!-- 查询表信息 --> |
| | | <select id="queryTableInfo" resultType="java.util.Map"> |
| | | SELECT a.attnum, |
| | |
| | | AND d.objsubid=a.attnum; |
| | | </select> |
| | | |
| | | |
| | | <!-- 统计计算全球管道图 --> |
| | | <select id="countGlobalPipeMap" resultType="java.util.Map"> |
| | | SELECT projname,count(*) AS count FROM bs.m_pipesegment group by projname ; |
| | |
| | | </select> |
| | | |
| | | <!-- 统计全国管网图输送介质长度 --> |
| | | <select id="countZhPipeMapLenByMed" resultType="java.util.Map"> |
| | | <!--select id="countZhPipeMapLenByMed" resultType="java.util.Map"> |
| | | SELECT medium AS type,count(*) AS count,sum(length)AS length FROM bs.m_pipesegment GROUP BY medium ; |
| | | </select--> |
| | | <select id="countZhPipeMapLenByMed" resultType="java.util.Map"> |
| | | select case medium when 'CO' then '原油' when 'RP' then '成品油' when 'GS' then '天然气' else '其它' end "type", |
| | | count(*) "count", round(sum(ST_Length(geom)::numeric), 2) "length" |
| | | from bs.m_pipeline |
| | | group by medium; |
| | | </select> |
| | | |
| | | <!-- 统计全国站场座数、阀室、管道数等 --> |
| | | <!-- 统计全国站场座数、阀室、管道数量 --> |
| | | <select id="countZhPipeStations" resultType="java.util.Map"> |
| | | select |
| | | case medium when 'CPY' then '成品油' when 'TRQ' then '天然气' when 'YY' then '原油' else '其它' end "输送介质", |
| | | case medium when 'CO' then '原油' when 'RP' then '成品油' when 'GS' then '天然气' else '其它' end "输送介质", |
| | | round(sum(st_length(geom))::numeric, 2) "总里程", |
| | | count(*) "管道数量", |
| | | (select count(*) from bs.m_sitepoint b inner join bs.m_pipeline c on b.pipename = c.pipename where c.medium = a.medium) "站场数量", |
| | |
| | | (select count(b.id) from lf.sys_meta b where dircode similar to '(' || (select string_agg(code, '|') from lf.sys_dir c where c.name = a.name) || ')%') "count", |
| | | (select coalesce(sum(b.sizes), 0) from lf.sys_meta b where dircode similar to '(' || (select string_agg(code, '|') from lf.sys_dir c where c.name = a.name) || ')%') "sizes" |
| | | from lf.sys_dir a |
| | | where code like '${projectCode}%' and name in ('基础测绘', '基础地灾', '基础勘察', '合规数据', '管理数据', '测量(ESV)', '勘察(EGE)', '地灾(EGD)', '洞库(EGD)') |
| | | where code like '${projectCode}%' and name in ('基础测绘', '基础地灾', '基础勘察', '合规数据', '管理数据', '测绘(ESV)', '勘察(EGE)', '地灾(EGD)', '洞库(EGD)') |
| | | group by name |
| | | order by name; |
| | | </select> |
| | |
| | | </select> |
| | | |
| | | <!-- 单个项目的下载个数、下载次数和数据量--> |
| | | <!-- select count(*) "number", sum(c.dcount) "count", sum(c.sizes) "size" |
| | | <!-- select count(*) "number", sum(c.dcount) "count", sum(c.sizes) "size" |
| | | from lf.sys_meta a inner join lf.sys_meta_down b on a.id = b.metaid |
| | | inner join lf.sys_download c on b.downid = c.id |
| | | where dircode like '${projectCode}%'; --> |
| | |
| | | where pid = 0 AND d.code like '${projectCode}%' |
| | | </select> |
| | | |
| | | <!-- 按大类统计 --> |
| | | <select id="countByMajor" resultType="com.lf.server.entity.ctrl.CountEntity"> |
| | | select '测绘(ESV)' "m1", '数字线划图' "m2", '平方千米' "m3", coalesce(sum(area), 0) "sizes" from lf.sys_line_buffer |
| | | union all |
| | | select '测绘(ESV)' "m1", '数字正射影像图' "m2", '平方千米' "m3", ( |
| | | select coalesce(sum(b.area), 0) from lf.sys_meta b |
| | | inner join lf.sys_dir c on b.dircode = c.code |
| | | where c.name = '数字正射影像图' and b.type in ('img', 'tif', 'tiff') ) "sizes" |
| | | union all |
| | | select '测绘(ESV)' "m1", '管线数据' "m2", '千米' "m3", |
| | | cast( coalesce(sum( ST_Length( ST_GeographyFromText( ST_AsText(geom) ) ) ) / 1000, 0) as decimal(12, 2) ) "sizes" from bs.m_pipeline |
| | | union all |
| | | select '勘察(EGE)' "m1", '勘探点' "m2", '个' "m3", count(*) "sizes" from bs.s_explorationpoint |
| | | union all |
| | | select '勘察(EGE)' "m1", '三维地质模型' "m2", '平方米' "m3", ( |
| | | select coalesce(sum(b.area), 0) from lf.sys_meta b |
| | | inner join lf.sys_dir c on b.dircode = c.code |
| | | where b.type in ('fbx', 'ifc', 'rvt') ) "sizes" |
| | | union all |
| | | select '地灾(EGD)' "m1", '地灾点' "m2", '个' "m3", count(*) "sizes" from bd.b_geologic_hazard; |
| | | </select> |
| | | |
| | | |
| | | |
| | | <!-- 查询中线缓冲区 --> |
| | | <select id="selectLineBuffer" resultType="java.lang.Integer"> |
| | | select fn_line_buffer(); |
| | | </select> |
| | | </mapper> |