Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Problem z zapytaniem - liczenie odległości w promieniu od punktu - Harvestine formula, Jak wyciągnąć z bazy odpowiednie wartości do wzoru
Kulfon
post
Post #1





Grupa: Zarejestrowani
Postów: 45
Pomógł: 2
Dołączył: 24.12.2010

Ostrzeżenie: (0%)
-----


Cześć! Męczę się i męczę i chyba nie dojdę do tego jak powinno to być...

Znalazłem/wymyśliłem kilka innych rozwiązań ale traktuję je póki co jako drogę na około, a nie prawdiłową drogę działania dlatego chciałbym zapytać jeszcze tutaj - moze uda się to zrobić jak należy, a nie na około.

Chcę liczyć odległość od punktu. Na to mamy odpowiedni wzór. Zapytanie do bazy też nie powinno przysparzać problemów ale tutaj sprawa się komplikuje. Otóż postawione na Wordpressie. I moje pytanie odnosi się tylko do zapytania. Tabela wygląda tak:
id post_id meta_key meta_value
640 11 lat 50.0952545
641 11 lng 20.078393600000027
642 11 address Kwiatowa 12
(tabela wp_postmeta)

Czyli ogólnie to co potrzebuję to:
- wyciągnąć z bazy wartości lat i lng
- policzyć dystans
- tam gdzie dystans jest mniejszy niż podany do zapytania zwrócić np. pole address

Na moment obecny mam takie coś:
  1. $wpdb->get_results(sprintf("SELECT meta_value, post_id, ( 3959 * acos( cos( radians('%s') ) * cos( radians( '%s' ) ) * cos( radians( '%s' ) - radians('%s') ) + sin( radians('%s') ) * sin( radians( '%s' ) ) ) )
  2. AS distance FROM wp_postmeta HAVING distance < '%s' ORDER BY distance LIMIT 0 , 200",
  3. mysql_real_escape_string($center_lat), // podana przez usera lat
  4. $wpdb->get_var("SELECT meta_value FROM wp_postmeta WHERE meta_key = 'lat'"), //brana z bazy wartosc lat
  5. $wpdb->get_var("SELECT meta_value FROM wp_postmeta WHERE meta_key = 'lng'"), //brana z bazy wartosc lng
  6. mysql_real_escape_string($center_lng), // podana przez usera lng
  7. mysql_real_escape_string($center_lat), podana przez usera lat
  8. $wpdb->get_var("SELECT meta_value FROM wp_postmeta WHERE meta_key = 'lat'"), //brana z bazy lat
  9. mysql_real_escape_string($radius)))//podany przez usera dystans


I nie wiem jak to doprowadzić do działania. Ogólnie wydaje mi się, że błąd popełniłem przy wybieraniu wlasnie z bazy tych lat i lng natomiast nie do końca wiem jak to zrobić. Czy mógłby mi ktoś powiedzieć jak powinno wyglądać prawidłowe zapytanie?




Edit:
Tak, siedzenie po nocach nie pomaga... Tutaj powinien być jakiś INNER JOIN zamiast sprintf'a prawda? (IMG:style_emoticons/default/biggrin.gif)

Ten post edytował Kulfon 18.02.2014, 14:01:26
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
Kulfon
post
Post #2





Grupa: Zarejestrowani
Postów: 45
Pomógł: 2
Dołączył: 24.12.2010

Ostrzeżenie: (0%)
-----


To niestety też jest błąd - dokładnie taki sam
Przykładowo zapytanie wygląda tak:
  1. SELECT r.post_id,
  2. sum(IF(meta_key = 'lat', meta_value, 0)) AS lat,
  3. sum(IF(meta_key = 'lng', meta_value, 0)) AS lng,
  4. ( 3959 * acos( cos( radians(50.0952545) ) * cos( radians( lat ) ) * cos( radians( lng ) - radians(20.078393600000027) ) + sin( radians(50.0952545) ) * sin( radians( lat ) ) ) )
  5. AS distance HAVING distance < 100
  6. FROM (SELECT post_id, meta_key, meta_value FROM wp_postmeta WHERE meta_key IN ('lat', 'lng')) r
  7. GROUP BY r.post_id LIMIT 0, 20


Ok, delikatnie zmieniłem zapytanie:

  1. SELECT r.post_id,
  2. sum(IF(meta_key = 'lat', meta_value, 0)) AS lat,
  3. sum(IF(meta_key = 'lng', meta_value, 0)) AS lng,
  4. ( 3959 * acos( cos( radians(50.0952545) ) * cos( radians( lat ) ) * cos( radians( lng ) - radians(20.078393600000027) ) + sin( radians(50.0952545) ) * sin( radians( lat ) ) ) )
  5. AS distance
  6. FROM (SELECT post_id, meta_key, meta_value FROM wp_postmeta WHERE meta_key IN ('lat', 'lng')) r HAVING distance < 100
  7. GROUP BY r.post_id LIMIT 0, 20


i teraz jeszcze:

You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'GROUP BY r.post_id' at line 7
Go to the top of the page
+Quote Post

Posty w temacie


Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 14.10.2025 - 00:43