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

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

新規登録して質問してみよう
ただいま回答率
85.47%
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)とは、インターネットがコンピュータなどの情報・通信機器のネットワークだけでなく、世の中のある様々なモノに接続されて自動認識・自動制御・遠隔計測などの能力を備えることです。「モノのインターネット」と一般的にいわれます。

Q&A

0回答

960閲覧

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

hideki.

総合スコア31

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クリップ

投稿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で良いやり方がありますでしょうか。

よろしくお願いします。

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

アカウントをお持ちの方は

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問