Solved

In ASP classic I need to search for the nearest plumbers within a 20 mile radius, given a zip code.

Posted on 2011-02-20
15
518 Views
Last Modified: 2012-05-11
This is a pretty common feature on many websites - like dating or "find a contractor" websites.

You'll enter in your zip code, then you enter in how many miles to "spread out" from this zip code, then the site displays for you all items within a, say, 5 mile radius of your zip code.

So I need to implement this functionality on my website but i have no idea where to start.

I have a database of every zip code in America.

And I have a database of all my plumbers around America

See image:

http://img17.imageshack.us/img17/3686/plumbers2.jpg

So when someone goes to my website and types in:

ZIP: 00501 Radius: 5

I need to show them all the plumbers I got within a 5 mile radius of their zip code.

Anyone got any ideas on how I would code that?

Since I have the longitude and latitude of all the zip codes, perhaps i'd have to do some sort of geometric heuristic?

I'm sure this is a classic computer science problem.

But I was only a computer science minor...

:)

little help?

Thanks!
0
Comment
Question by:bobbysdog
  • 7
  • 5
  • 3
15 Comments
 
LVL 7

Expert Comment

by:MrNed
Comment Utility
What database are you using? For example PostgreSQL with the PostGIS geospatial extensions can do all that with the inbuilt function calls. Trying to do something your self would be tricky and most likely slow without a lot of effort at understanding things like how R-tree indexes work.
0
 

Author Comment

by:bobbysdog
Comment Utility
wow really?

I'm just using MS Access and Classic ASP...
0
 
LVL 7

Expert Comment

by:MrNed
Comment Utility
I guess it depends on how big your site needs to be (users, data size, etc). You could code it up yourself fairly quickly with simple geometry functions and if there is only one user that might be acceptable. However, I'm used to catering for 1000s of users so haven't touched Access/ASP in a loooong time :) Just found that MySQL has spatial extensions too if you prefer that to postgresql, but I have never used them.
0
 

Author Comment

by:bobbysdog
Comment Utility
ya i would hope the site would eventually have thousands of visits a day.

damn that is a good link you posted...
0
 
LVL 7

Expert Comment

by:MrNed
Comment Utility
If you really want that much traffic, get off MS Access immediately :) It will NOT scale.
0
 
LVL 1

Expert Comment

by:axbernardi
Comment Utility
Hi.
If you want a very rough procedure (but it might be enoght for your purpose) you can run a query that take into consideration the coordinate of the two Post Code.
Then you can compare them keeping in mind that 1 degree of latitude it's always 69.2 miles.
1 degree of longitude unfortunately can vary with the latitude, but for the whole USA the value is between 48 and 58 (it is basically cos(latidude)*69.2 ) miles.
A couple of comparisson and you are roughly there!
0
 

Author Comment

by:bobbysdog
Comment Utility
>> "If you really want that much traffic, get off MS Access immediately :) It will NOT scale."

thanks - ya i know Access has its flaws. Unfortunately i'm not smart enough to use anything else. Hopefully, someone will buy my website for a million dollars and then they'll have to worry about optimizing it with a better database later :)

>> "If you want a very rough procedure (but it might be enoght for your purpose) you can run a query that take into consideration the coordinate of the two Post Code..."

hi

i think i follow your procedure. the thing is, there are 40,000 zip codes. So I think i'd need some sort of Spatial Database algo as described above - right?

0
Why You Should Analyze Threat Actor TTPs

After years of analyzing threat actor behavior, it’s become clear that at any given time there are specific tactics, techniques, and procedures (TTPs) that are particularly prevalent. By analyzing and understanding these TTPs, you can dramatically enhance your security program.

 
LVL 1

Expert Comment

by:axbernardi
Comment Utility
well, you said:

>> Since I have the longitude and latitude of all the zip codes, ...

so... there you go... that's your Spacial Database
0
 

Author Comment

by:bobbysdog
Comment Utility
Right

so i have this grid of x y coords

but the point is, I have 40,000 of them.

so the point of this thread is to try to find an algo that will get the 10 nearest points to

33.405559, -86.95141

and to do this in a fraction of a second (so i dont keep the user waiting...) and to implement this in ASP classic and MS Access on a typical windows server

0
 
LVL 1

Accepted Solution

by:
axbernardi earned 500 total points
Comment Utility
The initilal question was:
how to find the points at less than X miles from 33.405559, -86.95141.

Given the plumbers table done as
Name,ZIP,...

and the zips table done as
ZIP,lat,lon

the resulting query would be:

select plumbers.name,plumbers.ZIP from plumbers inner join zips on zips.ZIP=plumbers.ZIP
where abs(lat-33.405559)< X/55 and abs(lon- (-86.95141))<X/69.2

Open in new window


This query would actually not drow a circle but a square around the given point.

Generally speaking, the original point (the 33.405559, -86.95141) could be found with one first query at the beginning given the "search for" zip, with a simple
select lat,lon from zips where zip=TheGivenZip

Shouldn't take long to run this 2 query
0
 

Author Comment

by:bobbysdog
Comment Utility
Oooohhh

I see what you're getting at.

Ya thats cool. My website does not need to be precise at all. In fact if it guesses with a wide radius thats probably better.

but in your code, it looks like its only getting one side of the point...no?

wouldnt i need something like:

WHERE abs(lat-33.405559) < X/55 AND abs(lat-33.405559) > X/55

AND

abs(lon- (-86.95141)) < X/69.2 AND abs(lon- (-86.95141)) > X/69.2
0
 
LVL 1

Expert Comment

by:axbernardi
Comment Utility
No, you don't need that, that's the point of having an abs function!
so abs(33.41-33.45) = abs(-0.04) = 0.04
0
 

Author Comment

by:bobbysdog
Comment Utility
hmm

doesnt the abs value of a number just delete the neg sign

so in this case:

abs(lat-33.405559) <  X/55

wouldnt that just give me all the data on top of 33.40

like everything above San Francisco or thereabouts?
0
 
LVL 1

Expert Comment

by:axbernardi
Comment Utility
imagining X = 6 then X/55 = 0.11
33.5-33.4=0.1  --> abs= 0.1, included
33.3-33.4=-0.1 --> abs= 0.1 included
33.6-33.4=0.2  --> abs= 0.2, excluded
33.2-33.4=-0.2  --> abs= -0.2, excluded

so the formula will give you true for all values between 33.29 and 33.51
Ok??
0
 

Author Comment

by:bobbysdog
Comment Utility
oh i think i got it

thanks so much for helping me!!!!!!!!
0

Featured Post

Enabling OSINT in Activity Based Intelligence

Activity based intelligence (ABI) requires access to all available sources of data. Recorded Future allows analysts to observe structured data on the open, deep, and dark web.

Join & Write a Comment

Hello, all! I just recently started using Microsoft's IIS 7.5 within Windows 7, as I just downloaded and installed the 90 day trial of Windows 7. (Got to love Microsoft for allowing 90 days) The main reason for downloading and testing Windows 7 is t…
I would like to start this tip/trick by saying Thank You, to all who said that this could not be done, as it forced me to make sure that it could be accomplished. :) To start, I want to make sure everyone understands the importance of utilizing p…
In this seventh video of the Xpdf series, we discuss and demonstrate the PDFfonts utility, which lists all the fonts used in a PDF file. It does this via a command line interface, making it suitable for use in programs, scripts, batch files — any pl…
This video demonstrates how to create an example email signature rule for a department in a company using CodeTwo Exchange Rules. The signature will be inserted beneath users' latest emails in conversations and will be displayed in users' Sent Items…

728 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

10 Experts available now in Live!

Get 1:1 Help Now