<div>Hi,</div>
<div> </div>
<div>there is one way that may help you to speed them up. You can create another intermidiate table in Oracle or PostGIS, which contains the indexed column and the attribute column you are going to use for your queries in the MapInfo table, use this table to convert the query attributes into the index values in your MapInfo table, then you will get something you want.
</div>
<div> </div>
<div>Apparently, the best solution is what Bart has said. My suggestion is only one possibility to solve your problem.</div>
<div> </div>
<div>Regards</div>
<div> </div>
<div>Zhonghai<br> </div>
<div><span class="gmail_quote">On 2/27/07, <b class="gmail_sendername">Bart van den Eijnden (OSGIS)</b> <<a href="mailto:bartvde@osgis.nl">bartvde@osgis.nl</a>> wrote:</span>
<blockquote class="gmail_quote" style="PADDING-LEFT: 1ex; MARGIN: 0px 0px 0px 0.8ex; BORDER-LEFT: #ccc 1px solid">Hi,<br><br>I don't believe the Mapinfo attribute indexes are used by Mapserver/OGR.<br>This is not implemented.
<br><br>So if you need performance, store your data in e.g. PostGIS instead if<br>possible.<br><br>Best regards,<br>Bart<br><br>--<br>Bart van den Eijnden<br>OSGIS, Open Source GIS<br><a href="http://www.osgis.nl">http://www.osgis.nl
</a><br><br><br>--------- Oorspronkelijk bericht --------<br>Van: Jeppe Lund Andersen <<a href="mailto:JXA@COWI.DK">JXA@COWI.DK</a>><br>Naar: <a href="mailto:MAPSERVER-USERS@LISTS.UMN.EDU">MAPSERVER-USERS@LISTS.UMN.EDU
</a> <<a href="mailto:MAPSERVER-USERS@LISTS.UMN.EDU">MAPSERVER-USERS@LISTS.UMN.EDU</a>><br>Onderwerp: [UMN_MAPSERVER-USERS] queryByAttributes - speed<br>Datum: 27/02/07 09:34<br><br>> Hello all<br>><br>> Iam running php mapscript on a windows 2003 server and when Iam using
<br>> queryByAttributes, but it take some time to perform the search.<br>> It takes between 7-8 sek for this linie<br>><br>> $Qry = @$Layer-&gt;queryByAttributes($ID_navn, '(' . $Search_Str .')',
<br>> $ResultType);<br>><br>> The file iam using is a mapinfo file which has cadastral information.<br>> there are 156612 records in the file and the coln iam searching in has<br>> been index via mapifno.<br>
> the field is a text field<br>><br>> Am I doing something wrong ?<br>><br>> Jeppe<br>><br>> here is the funktion that load the map and perform the search<br>><br>> function FindExtendForMatrikel()
<br>> {<br>>       global $GISREF_LAYER_NAME, $MAP_PATH_NAME, $MAP_FILE_NAME,<br>> $MATRIKEL_ID_NAME;;<br>>       global $xmin, $ymin, $xmax, $ymax;<br>>       global $MATRIKEL_LAYER_NAME, $starttid, $kort;
<br>>       $Shape_matr = array();<br>><br>>       $Result = mssql_query (&quot;select * from kort WHERE name = '&quot;.<br>> $MATRIKEL_LAYER_NAME . &quot;'&quot;);<br>>       while ($row = mssql_fetch_array($Result))
<br>>       {<br>>               $Map = ms_newMapObj($MAP_FILE_NAME);<br>>               $Layer = ms_newLayerObj($Map);<br>>               $Layer-&gt;set('name', &quot;MatrikelSearchLayer&quot;);
<br>>               $Layer-&gt;set(&quot;connection&quot;, $row['MS_CONNECTION']);<br>>               $Layer-&gt;set(&quot;connectiontype&quot;, MS_OGR);<br>>               $Layer-&gt;set('status', MS_OFF);
<br>>               $Layer-&gt;set('type', MS_LAYER_POLYGON);<br>>               $Layer-&gt;setProjection($row['MS_PROJECTION']);<br>>               $Class = ms_newClassObj($Layer);<br>>               $Class-&gt;set('name', &quot;Matrikler&quot;);
<br>>               $Class-&gt;set('template', 'void');<br>>       }<br>><br>>       foreach ($kort-&gt;objekter as $value)<br>>       {<br>>               if ($value-&gt;ObjType() == &quot;Matrikel&quot;)
<br>>               {<br>><br>>                       $ID_value = $value-&gt;id;<br>>                       $Layer =<br>> $Map-&gt;getLayerByName(&quot;MatrikelSearchLayer&quot;);<br>>                       //$ID_value = &quot;78065110g&quot;;
<br>>                       $ID_navn = $MATRIKEL_ID_NAME;<br>>                       $ResultType = MS_MULTIPLE;<br>><br>>                       $Search_Str = &quot;&quot;;<br>>                       $matr_array = split(',', $ID_value);
<br>><br>>                       foreach ($matr_array as $matr)<br>>                       {<br>>                               if ($Search_Str != &quot;&quot;) {<br>>                                       $Search_Str .= &quot; OR &quot;;
<br>>                               }<br>>                               $Search_Str .= &quot; '[$ID_navn]' = '$matr'<br>> &quot;;<br>>                       }<br>><br>>                       $Qry = @$Layer-&gt;queryByAttributes($ID_navn, '('
<br>> .. $Search_Str .')', $ResultType);<br>>                       $QryRes = $Layer-&gt;getNumResults();<br>>                       if ($QryRes == 0 ) { $kort-&gt;matrikelsogning =<br>> NULL;}
<br>><br>>                       for ($I = 0; $I &lt; $QryRes; $I++)<br>>                       {<br>>                               $Res = $Layer-&gt;getResult($I);<br>>                               $Layer-&gt;open();
<br>>                               $Shape_matr[] =<br>> $Layer-&gt;getShape($Res-&gt;tileindex, $Res-&gt;shapeindex);<br>>                               $Layer-&gt;close();<br>><br>>                       }
<br>>               }<br>>       }<br>><br>> }<br>><br>><br></blockquote></div><br>