質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

2回答

773閲覧

GPSから取得したデータとDBに格納されているデータを比較して、 もっとも近い値のデータを取得したい。

jam912sh

総合スコア25

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2018/11/01 05:54

編集2018/11/01 05:59

前提・実現したいこと

GPSから取得したデータとDBに格納されているデータを比較して
もっとも近い値のデータを取得したいのですが、すべてのデータが取得されます。
PostgreSQLにお詳しい方、近似値の取得方法をご教示頂けますと幸いで御座います。
宜しくお願い致します。

発生している問題・エラーメッセージ

※36行目は「$this->query=pg_query($this->link,'SET NAMES utf8');」です。

PHP Warning: pg_query(): Query failed: ERROR: syntax error at or near "utf8" LINE 1: SET NAMES utf8  in /Applications/MAMP/htdocs/DatabaseClass.php on line 36

DB情報

title,latitude,longitude タイトルA,111111,222222 タイトルB,333333,444444 タイトルC,555555,666666 タイトルD,777777,888888 ※取得したGPSデータは「11112」「22223」としまして、近似値である「111111」「222222」の「タイトルA」のみが結果で帰ってくるのが理想です。

コード1(get_json.php)

<?php //DatabaseClassを読み込み include_once "DatabaseClass.php"; //テーブル名が選択されているかどうか確認 if($_POST["table_name"] ) { //DB名設定 $db_name = "test"; $database = new Database($db_name); $table_name = $_POST["table_name"]; // 取得したデータが緯度「latitude」が11112、経度「longitude」22223と設定しています。 // 比較後は、近似値の「title」のみを返す $sql = ("SELECT *, sqrt(power(abs(11112 - latitude),2) + power(abs(22223 - longitude),2)) FROM {$table_name} order by title "); //クエリ送信 $query = pg_query($sql); $json= array(); //テーブル名に「m_test」という文字列が入っているテーブルのデータをJSON形式で書き出し if(strstr($table_name, 'm_test')){ while ($row = $database->jsonparse($query)) { $json[] = array( 'title' => $row->title , ); } } //JSON形式で出力 header("Content-Type: application/json; charset=utf-8"); echo json_encode($json); //DBを閉じる $database->close(); } ?>

コード2(DatabaseClass.php)

<?php //内部文字コードを変更 mb_language("uni"); mb_internal_encoding("utf-8"); mb_http_input("auto"); mb_http_output("utf-8"); class Database{ var $dbServer; var $dbName; var $dbUser; var $dbPass; var $link; var $db; var $query; //DB接続 function __construct($db_name) { //DBの情報 $this->dbServer="localhost"; $this->dbName=$db_name; $this->dbUser="XXXXXX"; $this->dbPass="XXXXXX"; //ポスグレに接続 $this->link=pg_connect("host={$this->dbServer} dbname={$this->dbName} user={$this->dbUser} password={$this->dbPass}") or die(exit); //UTF-8の文字コードに変更 $this->query=pg_query($this->link,'SET NAMES utf8'); } //DBを閉じる public function close() { return pg_close($this->link); } //読み込むテーブルの選択 public function select($query) { $result=pg_query($query); $row=array(); $row=pg_fetch_assoc($result); return $row; } //指定したクエリの実行 public function query($query) { return pg_query($this->link,$query); } //JSON形式に変換用の出力 public function jsonparse($query) { $row = pg_fetch_object($query); return $row; } } ?>

補足情報(FW/ツールのバージョンなど)

phpバージョン:7.2.7
postgreSQLバージョン:10.5

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

SQLにLIMIT 1をつけましょう。
計算式は近場同士ならそれでもいいと思いますよ。

投稿2018/11/01 06:17

kgm

総合スコア275

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

jam912sh

2018/11/01 06:30 編集

kgm様、「LIMIT 1」の件、ご教示頂き有難うございます。さっそく「LIMIT 1」試してみましたが、今度は、何も値が返って来ないようで御座います。また「TOP 1」も同様で御座いました。貴重な情報を教えて頂き有難うございます! $sql = ("SELECT *, sqrt(power(abs(11112 - latitude),2) + power(abs(22223 - longitude),2)) FROM {$table_name} LIMIT 1 order by title ");
kgm

2018/11/01 06:33

limitはorder byの後に書いて下さい。
jam912sh

2018/11/01 06:37

kgm様、大変失礼致しました。limitはorder byの後に記載致しましたところ、期待動作となりました!大変助かりました。お忙しい中、教えて頂き有難うございました!
guest

0

以下の方法はいかがでしょうか。
近似値を求めるには?
こちらによれば、近似値を求める際はabswhere句で用いるみたいですね。

投稿2018/11/01 06:02

編集2018/11/01 06:03
madoka9393

総合スコア992

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

jam912sh

2018/11/01 06:16

madoka9393様、ご教示頂き有難うございます。教えて頂きましたサイトを参考に再度挑戦致します。有難う御座います。
jam912sh

2018/11/01 06:38

madoka9393様、こちらの件、無事解決致しました!お忙しい中、ご教示頂き有難う御座いました!大変勉強になりました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問