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%)
-----


Mam 1 testowy post. Było ich więcej ale na moment obecny działam na jednym. Wygląda to tak:

  1. --
  2. -- Struktura tabeli dla tabeli `wp_postmeta`
  3. --
  4.  
  5. CREATE TABLE `wp_postmeta` (
  6. `meta_id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT,
  7. `post_id` bigint(20) UNSIGNED NOT NULL DEFAULT '0',
  8. `meta_key` varchar(255) DEFAULT NULL,
  9. `meta_value` longtext,
  10. PRIMARY KEY (`meta_id`),
  11. KEY `post_id` (`post_id`),
  12. KEY `meta_key` (`meta_key`)
  13. ) ENGINE=MyISAM DEFAULT CHARSET=utf8;
  14.  
  15. --
  16. -- Zrzut danych tabeli `wp_postmeta`
  17. --
  18.  
  19. INSERT INTO `wp_postmeta` (`meta_id`, `post_id`, `meta_key`, `meta_value`) VALUES
  20. (411, 75, 'name', 'Miejsce 1'),
  21. (412, 75, 'address', 'Dywizjonu 303 11/505 30-123 KrakĂłw'),
  22. (420, 75, 'publicOrPrivate', 'public'),
  23. (423, 75, 'telefon', '123123123'),
  24. (426, 75, 'custom_logo', 'custom_logo_75.jpg'),
  25. (427, 75, 'custom_photo1', 'custom_photo1_75.jpg'),
  26. (428, 75, 'custom_photo2', 'custom_photo2_75.jpg'),
  27. (658, 75, 'lat', '50.08491009999999'),
  28. (659, 75, 'lng', '20.003797200000008');
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: 13.10.2025 - 18:55