1. package com.geoserver;
  2. import java.io.IOException;
  3. import java.util.ArrayList;
  4. import java.util.HashMap;
  5. import java.util.Map;
  6. import org.geotools.data.DataStore;
  7. import org.geotools.data.DataStoreFinder;
  8. import org.geotools.data.simple.SimpleFeatureCollection;
  9. import org.geotools.data.simple.SimpleFeatureSource;
  10. import org.geotools.feature.FeatureIterator;
  11. import org.geotools.filter.text.cql2.CQL;
  12. import org.geotools.filter.text.cql2.CQLException;
  13. import org.geotools.geometry.jts.ReferencedEnvelope;
  14. import org.opengis.feature.simple.SimpleFeature;
  15. import org.opengis.filter.Filter;
  16. /**
  17. * 采用geotools中公共查询语言
  18. * 过滤条件如下
  19. *
  20. * 例如:
  21. *    PERSONS > 15000000
  22. *    PERSONS BETWEEN 1000000 AND 3000000
  23. *    STATE_NAME LIKE 'N%'
  24. *    STATE_NAME = 'California'
  25. *    MALE > FEMALE
  26. *    UNEMPLOY / (EMPLOYED + UNEMPLOY) > 0.07
  27. *     IN ('states.1', 'states.12'):
  28. *   STATE_NAME IN ('New York', 'California', 'Montana', 'Texas'):
  29. *  带函数的使用:
  30. *     strToLowerCase(STATE_NAME) like ‘%m%’
  31. *
  32. *
  33. *
  34. * @Title:
  35. * @Description: 实现TODO
  36. * @Copyright:Copyright (c) 2011
  37. * @Company:
  38. * @Date:2012-9-10
  39. * @author  longgangbai
  40. * @version 1.0
  41. */
  42. public class GeoServerCQLECQL {
  43. /**
  44. *
  45. * @param filterStr
  46. * @param layerName
  47. * @return
  48. * @throws IOException
  49. */
  50. public static ArrayList<SimpleFeature> queryMethod(String filterStr,String layerName) throws IOException {
  51. String getCapabilities = "http://localhost:8080/geoserver/wfs?REQUEST=GetCapabilities";
  52. Map<String,String> connectionParameters = new HashMap<String,String>();
  53. connectionParameters.put("WFSDataStoreFactory:GET_CAPABILITIES_URL", getCapabilities );
  54. // Step 2 - connection
  55. DataStore data = DataStoreFinder.getDataStore( connectionParameters );
  56. SimpleFeatureSource featureSource =data.getFeatureSource(layerName);
  57. ArrayList<SimpleFeature> featureList = new ArrayList<SimpleFeature>();
  58. if(featureSource==null)
  59. return featureList;
  60. try {
  61. Filter  filter = CQL.toFilter(filterStr); // filterStr形式 如  name='武汉大学' or code like 'tt123%'
  62. SimpleFeatureCollection result = featureSource.getFeatures(filter);
  63. ReferencedEnvelope bounds = new ReferencedEnvelope();
  64. FeatureIterator<SimpleFeature> itertor = result.features();
  65. while (itertor.hasNext()) {
  66. SimpleFeature feature = itertor.next();
  67. bounds.include( feature.getBounds() );
  68. featureList.add(feature);
  69. }
  70. System.out.println( "Calculated Bounds:"+ bounds );
  71. itertor.close();
  72. result.close( itertor );
  73. return featureList;
  74. } catch (CQLException e) {
  75. // TODO Auto-generated catch block
  76. e.printStackTrace();
  77. } catch (IOException e) {
  78. // TODO Auto-generated catch block
  79. e.printStackTrace();
  80. }finally {
  81. }
  82. return null;
  83. }
  84. public static void main(String[] args) throws IOException {
  85. ArrayList<SimpleFeature> list=queryMethod("STATE_NAME='Arizona'","topp:states");
  86. System.out.println("list="+list.toString());
  87. }
  88. }

geoserver中除了使用kml来查询数据以外,还可以使用csql或ecsql的更多相关文章

  1. 关于EsayUI中datagrid重复提交后台查询数据的问题

    直接上代码: <table id="XXXX" style="width:100%;height:100%;" class="easyui-da ...

  2. Lucene 06 - 使用Lucene的Query API查询数据

    目录 1 Query对象的创建(方式一): 使用子类对象 1.1 常用的Query子类对象 1.2 常用的Query子类对象使用 1.2.1 使用TermQuery 1.2.2 使用NumericRa ...

  3. [原]在GeoServer中为OpenStreetMap数据设置OSM样式

    转载请注明作者think8848和出处(http://think8848.cnblogs.com) 在前面几篇文章中,我们讲到了部署Postgresql,部署PostGis,部署GeoServer以及 ...

  4. Python3操作MySQL,查询数据并保存到文件中

    我们在测试过程中,可能需要到数据库中拉去一些数据,为从测试准备.比如最近在做接口性能测试的时候,就需要很多数据来支撑,所以就需要的数据库去查询数据,下面就是python3 查询 mysql 并且保存到 ...

  5. MySQL查询数据表中数据记录(包括多表查询)

    MySQL查询数据表中数据记录(包括多表查询) 在MySQL中创建数据库的目的是为了使用其中的数据. 使用select查询语句可以从数据库中把数据查询出来. select语句的语法格式如下: sele ...

  6. Sql Server 存储过程中查询数据无法使用 Union(All)

    原文:Sql Server 存储过程中查询数据无法使用 Union(All) 微软Sql Server数据库中,书写存储过程时,关于查询数据,无法使用Union(All)关联多个查询. 1.先看一段正 ...

  7. 关于SpringMVC中如何把查询数据全转成String类型

    之前,本想与客户商量做几张固定的报表予使用,结果发现客户每个月都需要各种各样的报表,所以我们做了个窗口用于直接执行SQL语句:数据量一开始并不是很大查询出来的数据较少(约1-6W左右),所以刚开始几个 ...

  8. 从DataTable中查询数据

    /// <summary> /// 从DataTable中查询数据 /// </summary> /// <param name="tb">待处 ...

  9. 2019-2-14SQLserver中拼音查询数据

    SQLserver中获取文字的全拼音: CREATE function [dbo].[f_GetPinyin](@words nvarchar()) returns varchar() as begi ...

随机推荐

  1. re模块 ,random模块

    # 在python中使用正则表达式 # 转义符 : 在正则中的转义符 \ 在python中的转义符# 正则表达式中的转义 :# '\(' 表示匹配小括号# [()+*?/$.] 在字符组中一些特殊的字 ...

  2. faker模块基本用法

    引言: 自动化脚本编写时,一般会遇到需要构造数据的情况,比如注册时的基本信息:每次执行脚本都要重新构造数据显然是很费时费力的事情,所以可以用到faker模块来构造:方便快捷,神器也: 一.安装 pip ...

  3. uva-10004-俩色图验证

    题意: 在1976年,四色猜想被一个计算机助手提出,这个理论表示对任意一个地图的上色都只需要四种颜色,地图内每一个区块和相邻的区块颜色都不相同.你现在被要求解决一个相似但相对简单的问题.给你任意一个连 ...

  4. Python正则总结

    re总结 限定符(就是控制重复次数) ? 匹配前面的子表达式零次或一次.例如,"do(es)?" 可以匹配 "do" . "does" 中的 ...

  5. windows巡检

    参考网站:   http://www.jb51.net/os/windows/525017.html 系统自带工具巡检  : 先说说如何检查系统健康度的方法,Win+R只有只要输入一个命令: perf ...

  6. ajax 遍历json一维数组

    $.each(data,function(index,value){}data必须是Object类型index是数组的下标value可以是一个对象 function myonclick() { var ...

  7. 关于消息队列的使用----ActiveMQ,RabbitMQ,ZeroMQ,Kafka,MetaMQ,RocketMQ

    一.消息队列概述消息队列中间件是分布式系统中重要的组件,主要解决应用解耦,异步消息,流量削锋等问题,实现高性能,高可用,可伸缩和最终一致性架构.目前使用较多的消息队列有ActiveMQ,RabbitM ...

  8. Java Integer值用==和equals相等问题

    来自 http://blog.csdn.net/w112736112736/article/details/77986283

  9. Kotlin语言学习笔记(7)

    反射 // 反射 val c = MyClass::class val c2 = MyClass::class.java // 获取KClass的引用 val widget: Widget = ... ...

  10. Cache Lucene IndexReader with Apache Commons Pool

    IndexReaderFactory.java 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 2 ...