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

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

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

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

SQL

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

IoT

IoT(Internet of Things)とは、インターネットがコンピュータなどの情報・通信機器のネットワークだけでなく、世の中のある様々なモノに接続されて自動認識・自動制御・遠隔計測などの能力を備えることです。「モノのインターネット」と一般的にいわれます。

受付中

IoTデータで取得タイミングが異なるデータの紐付け処理方法

hideki.
hideki.

総合スコア17

PostgreSQL

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

SQL

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

IoT

IoT(Internet of Things)とは、インターネットがコンピュータなどの情報・通信機器のネットワークだけでなく、世の中のある様々なモノに接続されて自動認識・自動制御・遠隔計測などの能力を備えることです。「モノのインターネット」と一般的にいわれます。

0回答

0評価

0クリップ

479閲覧

投稿2021/08/31 07:03

図1に示すような製造ライン(最高生産速度2個/秒)があります。
ロールを巻き出してプロセスA~Cで加工を加えて、最後に自動検査機で検査します。
プロセス状態モニタリングとして、各プロセスの状態を1秒毎にテーブルに保存してます。
検査結果は検査毎に別のテーブルに記録されてます(DBはPostgreSQL)。
イメージ説明

やりたいことは製品の検査結果とプロセス状態を一つのレコードにまとめることです。
つまり、図2の左テーブルの該当レコードのデータを参照して右側のようなテーブルを生成して検査結果のテーブルと結合させることです。
これにより、検査NGのときのプロセス状態を知ることができます。
イメージ説明

データ突き合わせ手順(検査結果テーブルに設備・プロセスデータをJOINする場合)
0. 検査結果、最初の行の時刻「17:22:45.1」に近い時刻を設備信号テーブルから探すと「17:22:45」が見つかり、そのカウント値(shot counter)は21。
0. dt_aの値は10ピッチ前なので、カウント11のレコードのdt_aの値を参照し、1.6を得る。
0. dt_bの値は8ピッチ前なので、カウント13のレコードのdt_bの値を参照し、30を得る。
0. dt_cの値は4ピッチ前なので、カウント17のレコードのdt_cの値を参照し、55を得る。
0. チョコ停や生産速度変更が想定されるので、検査結果2行目以降も1-4と同様の処理の繰り返し。

尚、設備信号のスキャン周期の関係で、カウント値は歯抜けになるので、該当するカウント値のレコードをサーチする場合は条件を「一致」でなく、「最も近い」とします。

教えて頂きたいのはこの処理をSQLで書くことは適当か、です。
SQL初心者の自分はどう考えてもループでSQLクエリを何度も発行するような処理になりそうです。図2に相当するデータ抽出のみをSQLで行い、生成処理はPythonなどのプログラミング言語を使用して書いた方が良いでしょうか。
それともSQLで良いやり方がありますでしょうか。

よろしくお願いします。

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

PostgreSQL

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

SQL

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

IoT

IoT(Internet of Things)とは、インターネットがコンピュータなどの情報・通信機器のネットワークだけでなく、世の中のある様々なモノに接続されて自動認識・自動制御・遠隔計測などの能力を備えることです。「モノのインターネット」と一般的にいわれます。