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

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

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

Oracleは、米オラクルが取り扱うリレーショナルデータベース管理システムです。メインフレームからPCまで、多様なプラットフォームに対応しています。

Q&A

解決済

1回答

456閲覧

データの空いた週数にデータを挿入したい

JuguarSugar

総合スコア83

Oracle

Oracleは、米オラクルが取り扱うリレーショナルデータベース管理システムです。メインフレームからPCまで、多様なプラットフォームに対応しています。

0グッド

0クリップ

投稿2021/04/23 09:38

下表は基準日に対して測定日がある血圧測定データです。

|患者コード|基準日|測定日|血圧|True/False
|:--|:--:|--:|
50815|20140630|20141122|106|F
50815|20140630|20141220|108|F
50815|20140630|20150114|107|F
50815|20140630|20150207|92|F
50815|20140630|20150225|124|F
50815|20140630|20150307|119|F
50815|20140630|20150318|112|F
50815|20160713|20160823|109|F
50815|20160713|20160906|101|F
50815|20160713|20160920|113|F
50815|20160713|20161011|85|F
50815|20160713|20161108|92|F
50815|20160713|20161208|106|F
50815|20160713|20170110|127|F
50815|20160713|20170124|110|F
50815|20160713|20170207|120|F
50815|20160713|20170221|99|F
50815|20190707|20190806|118|F
50815|20190707|20190910|107|F
50815|20190707|20191008|120|F
50815|20190707|20191105|114|F
50815|20190707|20191205|118|F
50815|20190707|20200109|120|F
50815|20190707|20210129|132|F

このデータの上2行の測定日 "20141122","20141220" を見ると日付間が4週離れているのが分かります。
間の週は "20141129","20141206","20141213" の3週です。
この間の週のレコードを追加したいです。

血圧は週数と同じく3で割った値を入れていき、
1週目は血圧 "106"~"108"の間の25%の数字、
2週目は50%の数字、
3週目は75%くらいの数字としたいです。

そして追加したレコードはTrue/False列を Tにしたいです。

具体的には下表のようにしたいと考えています。
|患者コード|基準日|測定日|血圧|True/False
|:--|:--:|--:|
50815|20140630|20141122|106|F
50815|20140630|20141129|106|F
50815|20140630|20141206|107|F
50815|20140630|20141213|107|F
50815|20140630|20141220|108|F

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

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

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

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

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

mather

2021/04/23 14:35

ご自身でやってみてわからない部分を質問してください。 このままでは丸投げ(実装依頼)の投稿になってしまいます。
guest

回答1

0

ベストアンサー

欠けているものを見つけるには、基準となるものが必要です。
質問の内容で必要なのは週のカレンダーで、そのカレンダーに対して存在していない日付のデータを追加するようにします。

SQL

1insert into テーブル(項目) 2select 項目 3from カレンダー left join テーブル  4 on カレンダー.日付=テーブル.日付 5where テーブル.キー is null

カレンダーは実際のテーブルでも良いですし、CONNECT BY LEVELを用いて仮想表を生成してもいいでしょう。
Level擬似列
OracleでのPostgreSQLの「generate_series」(連続値の生成関数)的な使い方(LEVEL疑似列)

細々な編集があって追加時の値の判断が難しいなら、日付だけ追加した後に更新するなどすれば良いかと思いますが、それならいっそ、無名ブロックで順次読み出しして追加する方が良い気がします。

SQL

1-- 無名ブロック 2DECLARE 3 wr record; 4BEGIN 5 for wr in ( 6 select tbl.* 7 , to_date(lead(測定日) over(order by 測定日), 'yyyymmdd') - to_date(測定日, 'yyyymmdd') as 測定間隔日数 8 from テーブル tbl order by 測定日 9 ) loop 10 for i in 1..(wr.測定間隔日数 / 7) loop 11 -- insert 処理 12 end loop; 13 end loop; 14END;

投稿2021/04/24 05:27

編集2021/04/24 13:53
sazi

総合スコア25327

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問