[mapserver-users] [EXTERNAL] Re: Mapserver 7+oracle - wfs getFeature with filter on numeric field
Steve.Toutant at inspq.qc.ca
Steve.Toutant at inspq.qc.ca
Thu May 14 06:48:11 PDT 2015
And setting it to true doesn't make more sense.
I guess it is already not used when the source is postgis
Thank you very much for your help in this
Steve
"Smith, Michael ERDC-RDE-CRREL-NH" <Michael.Smith at erdc.dren.mil>
2015-05-14 09:43
A
"Steve.Toutant at inspq.qc.ca" <Steve.Toutant at inspq.qc.ca>
cc
MapserverList OSGEO <mapserver-users at lists.osgeo.org>, thomas bonfort
<thomas.bonfort at gmail.com>
Objet
Re: [EXTERNAL] Re: [mapserver-users] Mapserver 7+oracle - wfs getFeature
with filter on numeric field
The matchCase triggers a string comparison. matchCase doesn't seem to make
sense for a number.
That being said, I can look into the specific case of matchCase and a
numeric comparison and make sire that it isn't used.
Mike
----
Michael Smith
US Army Corps
Remote Sensing GIS/Center
michael.smith at usace.army.mil
From: "Steve.Toutant at inspq.qc.ca" <Steve.Toutant at inspq.qc.ca>
Date: Thursday, May 14, 2015 at 9:28 AM
To: Michael Smith <michael.smith at erdc.dren.mil>
Cc: MapserverList OSGEO <mapserver-users at lists.osgeo.org>, thomas bonfort
<thomas.bonfort at gmail.com>
Subject: Re: [EXTERNAL] Re: [mapserver-users] Mapserver 7+oracle - wfs
getFeature with filter on numeric field
Is there a documentation that says that it is not?
Folks from gdal list also think that it is not supported...I guess you are
right. But as I said on the gdal list, many countries are using a comma as
a decimal separator....what other people on the planet do?
Anyway the comma is another problem that I try to manage later......
For now, We have an application that generate and launch spatial queries
on WFS, matchCase=false by default. Before modifying the code I want to
understand what is going on....
It seems,when using numeric value, that matchCase as no impact in PostGIS,
but it is important in oracle to be set to true
gml_type = auto, returns double in postgis and oracle, so that is fine
A WFS getFeature with the operator PropertyIsEqualTo AND matchCase=false
using this value -64.225
PostGis: it works
Oracle (from mike's test): it fails...matchCase must be set to true
A WFS getFeature with the operator PropertyIsEqualTo AND matchCase=false
using this value -64,225
PotsGis: not tested
Oracle: it fails...matchCase must be set to true
Is there a reason why, with oracle, matchCase should be set to true when
using numeric value, or that could be fixed?
Regards
Steve
"Smith, Michael ERDC-RDE-CRREL-NH" <Michael.Smith at erdc.dren.mil>
2015-05-14 09:17
A
"Steve.Toutant at inspq.qc.ca" <Steve.Toutant at inspq.qc.ca>
cc
MapserverList OSGEO <mapserver-users at lists.osgeo.org>, thomas bonfort <
thomas.bonfort at gmail.com>
Objet
Re: [EXTERNAL] Re: [mapserver-users] Mapserver 7+oracle - wfs getFeature
with filter on numeric field
Its not clear to me that commas as the decimal separator is supported in
XML/GML. I can't find any documentation to indicate that it is. Can you
point some out to me?
In any event, I didn't test with comma decimal separators.
Mike
----
Michael Smith
US Army Corps
Remote Sensing GIS/Center
michael.smith at usace.army.mil
From: "Steve.Toutant at inspq.qc.ca" <Steve.Toutant at inspq.qc.ca>
Date: Thursday, May 14, 2015 at 8:54 AM
To: Michael Smith <michael.smith at erdc.dren.mil>
Cc: MapserverList OSGEO <mapserver-users at lists.osgeo.org>, thomas bonfort
<thomas.bonfort at gmail.com>
Subject: Re: [EXTERNAL] Re: [mapserver-users] Mapserver 7+oracle - wfs
getFeature with filter on numeric field
Thanks Mike for having a look at it.
Your decimals are separated by a comma or a dot?
"Smith, Michael ERDC-RDE-CRREL-NH" <Michael.Smith at erdc.dren.mil>
2015-05-13 18:53
A
"Steve.Toutant at inspq.qc.ca" <Steve.Toutant at inspq.qc.ca>, thomas bonfort <
thomas.bonfort at gmail.com>
cc
MapserverList OSGEO <mapserver-users at lists.osgeo.org>
Objet
Re: [EXTERNAL] Re: [mapserver-users] Mapserver 7+oracle - wfs getFeature
with filter on numeric field
Steve,
I tested this out with 7.1 with numeric type fields and it works for me as
long as I don't use matchCase="false". That seems to kick it in to a
string comparison. matchCase="true" and just PropertyIsEqualTo work fine.
In our metadata we use "gml_types" "auto" when the database knows the
types and explicit declarations (eg "gml_attributename_type" "integer")
when it doesn't work.
The key is that the field type has to report as a numeric type or the
backend treats it as a string comparison.
Mike
----
Michael Smith
US Army Corps
Remote Sensing GIS/Center
michael.smith at usace.army.mil
From: "Steve.Toutant at inspq.qc.ca" <Steve.Toutant at inspq.qc.ca>
Date: Wednesday, May 13, 2015 at 10:35 AM
To: thomas bonfort <thomas.bonfort at gmail.com>
Cc: MapserverList OSGEO <mapserver-users at lists.osgeo.org>
Subject: [EXTERNAL] Re: [mapserver-users] Mapserver 7+oracle - wfs
getFeature with filter on numeric field
Resent-From: Michael Smith <michael.smith at usace.army.mil>
Precision: we are using MS7.1
Removing matchcase part makes oracle, and postgis, crash.
I have this error:
<ows:ExceptionReport xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:ows="http://www.opengis.net/ows" version="1.1.0"
language="en-US"xsi:schemaLocation="http://www.opengis.net/ows< /a>
http://schemas.opengis.net/ows/1.0.0/owsExceptionReport.xsd">
<ows:Exception exceptionCode="NoApplicableCode" locator="mapserv">
<ows:ExceptionText>
msWFSGetFeature(): WFS server error. FLTApplyFilterToLayer() failed
msOracleSpatialLayerWhichShapes(): OracleSpatial error. Check your data
statement and server logs
</ows:ExceptionText>
The problem might be the decimals?
Here is the request
<wfs:Query typeName="feature:SMDVDP_STAT_METE" srsName="EPSG:32198">
<ogc:Filter xmlns:ogc="http://www.opengis.net/ogc">
<ogc:PropertyIsEqualTo>
<ogc:PropertyName>LONG_STAT</ogc:PropertyName>
<ogc:Literal>-61,8031</ogc:Literal>
</ogc:PropertyIsEqualTo>
</ogc:Filter>
</wfs:Query>
</wfs:GetFeature>
thomas bonfort <thomas.bonfort at gmail.com>
2015-05-13 05:40
A
Steve.Toutant at inspq.qc.ca
cc
MapserverList OSGEO <mapserver-users at lists.osgeo.org>
Objet
Re: [mapserver-users] Mapserver 7+oracle - wfs getFeature with filter on
numeric field
can you try the same request without the "matchCase" part and report
back please?
On 12 May 2015 at 18:11, <Steve.Toutant at inspq.qc.ca> wrote:
> I have a problem using a FILTER in a wfs getFeature request on an oracle
DB
> with MS7
> When I launch a getFeature request with a Filter on a numeric field it
> doesn't work,
> <ogc:Filter xmlns:ogc="http://www.opengis.net/ogc
"><ogc:PropertyIsEqualTo
>
matchCase="false"><ogc:PropertyName>LONG_STAT</ogc:PropertyName><ogc:Literal>-61</ogc:Literal></ogc:PropertyIsEqualTo></ogc:Filter>
> here is the error we get in the browser
> <ows:Exception exceptionCode="NoApplicableCode" locator="mapserv">
> <ows:ExceptionText>msWFSGetFeature(): WFS server error.
> FLTApplyFilterToLayer() failed
> msOracleSpatialLayerWhichShapes(): OracleSpatial error. Check your data
> statement and server logs</ows:ExceptionText>
>
> from mapserver logs
> [Tue May 12 11:59:10 2015].177992 msOracleSpatialLayerTranslateFilter.
> String: ([LONG_STAT] =*-61)
>
> LONG_STAT is a NUMBER in the DB
> DescribefeatureType returns
> <element name="NO_STAT_CLIM" minOccurs="0" type="string"/>
> <element name="NO_STAT_FADQ" minOccurs="0" type="string"/>
> <element name="NOM_STAT" minOccurs="0" type="string"/>
> <element name="LATI_STAT" minOccurs="0" type="string"/>
> <element name="LONG_STAT" minOccurs="0" type="string"/>
> <element name="ALTI_STAT" minOccurs="0" type="string"/>
>
> I tried to add "gml_types" "auto" in the mapfile, but it still returns
> string as data type
> I tried "gml_LONG_STAT_type" = "Integer" in the mapfile,
describeFeatureType
> returns "<element name="LONG_STAT" minOccurs="0" type="double"/> " but I
> still get an error in getFeature
>
> I'm using CONNECTIONTYPE oraclespatial in the mapfile
>
> I can provide more information....
>
> Is it a known issue or can I do something about that?
>
> Thank you!
> _______________________________________________
> mapserver-users mailing list
> mapserver-users at lists.osgeo.org
> http://lists.osgeo.org/mailman/listinfo/mapserver-users
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.osgeo.org/pipermail/mapserver-users/attachments/20150514/bf8b9df7/attachment.htm>
More information about the MapServer-users
mailing list