[postgis-users] latitude / longitude from wkb_geometry
Emily Gouge
egouge at refractions.net
Mon Feb 12 09:07:52 PST 2007
If you want to extract all the points in a linestring with a single query you can try the
generate_series function:
For Example:
SELECT astext( pointn(the_geom, generate_series(1, numpoints(the_geom))))
FROM (select geomfromtext('LINESTRING(0 0, 1 1, 2 2)') as the_geom) as foo;
Returns:
astext
------------
POINT(0 0)
POINT(1 1)
POINT(2 2)
(3 rows)
Pedro Doria Meunier wrote:
> Hi Mark
>
> Please see the previous email (to this one).
> pointn() starts at 1, not 0... ;-)
>
> So the sql statement should be:
> SELECT x(pointn(wkb_geometry,1)), y(pointn(wkb_geometry,1)) from masuf
> where ogc_fid=62560;
>
> This returns the first point of the linestring object.
>
> Cheers,
> Pedro.
>
> -----Original Message-----
> From: postgis-users-bounces at postgis.refractions.net
> [mailto:postgis-users-bounces at postgis.refractions.net] On Behalf Of mark
> Sent: segunda-feira, 12 de Fevereiro de 2007 16:42
> To: PostGIS Users Discussion
> Subject: Re: [postgis-users] latitude / longitude from wkb_geometry
>
> Hi Pedro
> Thanks for your replies.
> I tried your SQL query on this row:
>
> SELECT x(pointn(wkb_geometry,0)), y(pointn(wkb_geometry,0)) from masuf
> where ogc_fid=62560;
> "62560";"0102000020AD10000002000000E65DF580797A5EC01EA67D737FA54240978C63247
> B7A5EC07DAEB6627FA54240";"TGR06085";"123181609";"";"O";"";"";"";"";"F10";"";
> "";"";"";"";"";"";"";"";"";"";"";"";"";"";"";"6";"6";"85";"85";"92830";"9283
> 0";"";"";"68000";"68000";"502601";"502601";"1019";"1019"
>
> I just get Null values for x and y.
>
> Can you tell what is wrong?
> thanks a lot!
> mark
>
>
> On 2/12/07, Pedro Doria Meunier <pdoria at netmadeira.com> wrote:
>> Hi Mark
>>
>> Addendum to the previous post...
>> I didn't notice that the geometry was LINESTRING :]
>> So what we need here is to concatenate some functions:
>>
>> SELECT x(pointn(wkb_geometry,0)), y(pointn(wkb_geometry,0)) from masuf;
>>
>> This will give you the first coordinate of each line.
>>
>> Should you want to process all coordinates of each linestring here's a
>> little PHP that might help:
>>
>> // ------ cut here
>> <?php
>> $connection = pg_connect("host=yourhost port=5432 dbname=yourdb
>> user=yourusername password=yourpassword");
>> if (!$connection) {
>> print("Connection to the database failed.");
>> exit;
>> }
>> /*
>> Get all the records from the table.
>> We get the unique ogc_fid and the corresponding number of points for the
>> linestring of this entry...
>> */
>> $sql="SELECT ogc_fid, numpoints(wkb_geometry) from masuf";
>> $myresult=pg_exec($connection, $sql);
>>
>> for ($row=0; $row<pg_numrows($myresult); $row++) {
>> $unique=pg_result($myresult,$row,0);
>> $npoints==pg_result($myresult,$row,0);
>> // now we process each point in this entry
>> for ($point=0; $point<$npoints; $point++) {
>> $sql= "SELECT x(pointn(wkb_geometry,$point)),
>> y(pointn(wkb_geometry,$point)) FROM masuf WHERE ogc_fid='$unique'";
>> $presult=pg_exec($connection, $sql);
>> $lon=pg_result($presult,0,0);
>> $lat=pg_result($presult,0,1);
>> /*
>> Do whatever you wish with $lon, $lat....
>> */
>> }
>> }
>> ?>
>> // ------ cut here
>>
>>
>> If the gurus out there have a more efficient way to do this, I'd be more
>> than interested in hearing about it! ;-)
>>
>> HTH,
>> Pedro Doria Meunier.
>>
>>
>> -----Original Message-----
>> From: postgis-users-bounces at postgis.refractions.net
>> [mailto:postgis-users-bounces at postgis.refractions.net] On Behalf Of mark
>> Sent: segunda-feira, 12 de Fevereiro de 2007 5:57
>> To: postgis-users at postgis.refractions.net
>> Subject: [postgis-users] latitude / longitude from wkb_geometry
>>
>> how to get latitude and longitude from wkb_geometry?
>> My table structure is given below
>> thanks
>> mark
>>
>> CREATE TABLE masuf
>> (
>> ogc_fid serial NOT NULL,
>> wkb_geometry geometry,
>> module char(8),
>> tlid numeric(10),
>> side1 numeric(1),
>> source char(1),
>> fedirp char(2),
>> fename char(30),
>> fetype char(4),
>> fedirs char(2),
>> cfcc char(3),
>> fraddl char(11),
>> toaddl char(11),
>> fraddr char(11),
>> toaddr char(11),
>> friaddl char(1),
>> toiaddl char(1),
>> friaddr char(1),
>> toiaddr char(1),
>> zipl numeric(5),
>> zipr numeric(5),
>> aianhhfpl numeric(5),
>> aianhhfpr numeric(5),
>> aihhtlil char(1),
>> aihhtlir char(1),
>> census1 char(1),
>> census2 char(1),
>> statel numeric(2),
>> stater numeric(2),
>> countyl numeric(3),
>> countyr numeric(3),
>> cousubl numeric(5),
>> cousubr numeric(5),
>> submcdl numeric(5),
>> submcdr numeric(5),
>> placel numeric(5),
>> placer numeric(5),
>> tractl numeric(6),
>> tractr numeric(6),
>> blockl numeric(4),
>> blockr numeric(4),
>> CONSTRAINT masuf_pk PRIMARY KEY (ogc_fid),
>> CONSTRAINT enforce_dims_wkb_geometry CHECK (ndims(wkb_geometry) = 2),
>> CONSTRAINT enforce_geotype_wkb_geometry CHECK
>> (geometrytype(wkb_geometry) = 'LINESTRING'::text OR wkb_geometry IS
>> NULL),
>> CONSTRAINT enforce_srid_wkb_geometry CHECK (srid(wkb_geometry) = 4269)
>> )
>> _______________________________________________
>> postgis-users mailing list
>> postgis-users at postgis.refractions.net
>> http://postgis.refractions.net/mailman/listinfo/postgis-users
>>
>>
>> _______________________________________________
>> postgis-users mailing list
>> postgis-users at postgis.refractions.net
>> http://postgis.refractions.net/mailman/listinfo/postgis-users
>>
> _______________________________________________
> postgis-users mailing list
> postgis-users at postgis.refractions.net
> http://postgis.refractions.net/mailman/listinfo/postgis-users
>
>
> _______________________________________________
> postgis-users mailing list
> postgis-users at postgis.refractions.net
> http://postgis.refractions.net/mailman/listinfo/postgis-users
More information about the postgis-users
mailing list