![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?5a7ff87)
テーブルが2つありまして、既存テーブルには
担当者コードが入っておらず(フィールドはあります)、その担当者コードフィールドへ既存テーブルの時刻からそれに合った担当者コードを担当者テーブルからを参照し登録する作業を行いたいのですが、1つのSQL文で可能なのでしょうか?
既存テーブル
ID,InDate(時刻),UserCode(担当者コード)
1,2006-09-01 10:20:30,''
2.2006-09-02 12:10:50,''
担当者テーブル
UserCode,UserName,StartTime,EndTime
111,ABC,2006-09-01 09:00:00,2006-09-01 13:30:00
222,DEF,2006-09-02 09:00:00,2006-09-01 13:30:00
の様なデータが合った場合
既存テーブルのID1のUserCodeへ111
既存テーブルのID2のUserCodeへ222
と入れるようなSQLを作成したいのです。
update 既存テーブル set usercode =
(select b.usercode
from 既存テーブル as a,担当者テーブル as b
where a.InDate > b.starttime
and a.InDate < b.endtime);
と作成はしてみたものの
ERROR: more than one row returned by a subquery used as an expression
とエラー表示されます。
複数のレコードがあるからエラー?ってことなのでしょうか。
ver:PostgreSQL 8.1
どのようにすると、可能になるか教えてほしいのですが、どうぞよろしくお願いします。(説明がうまく出来ず申し訳ありません…)
No.1ベストアンサー
- 回答日時:
担当者テーブルのUserCode=222のEndTimeは、9月2日のデータの誤りですね?
update文にfrom句を使う指定方法があり、これを使うと簡単です。
update 既存テーブル
set UserCode=担当者テーブル.UserCode
from 担当者テーブル
where InDate between StartTime and EndTime
早速の回答有り難うございます。
ご指摘の通り、9月2日のデータのEndTimeは2006-09-02の間違いです。
回答の通りSQLを作成した所、うまく動作する事が
出来ました。
有り難うございました。
申し訳ありませんが、もう1つあるのですが、
もし担当者コード222のEndTimeが入ってない場合
(その担当者が引き続き運用中の為、終了時刻が入っていない)も同様にID2の担当者コードには222と入れたいのですが方法はありますでしょうか。
度々申し訳ありませんが、よろしくお願いします。
No.2
- 回答日時:
>もし担当者コード222のEndTimeが入ってない場合
>(その担当者が引き続き運用中の為、終了時刻が入っ>ていない)も同様にID2の担当者コードには222と入れ>たいのですが方法はありますでしょうか。
終了時刻の入れ方にも、いろいろ方法がありますよね。
例えば、nullとする方法もありますが、この方法では、範囲や大小比較で「終了であること」を判別する仕組みが必要になります。
もっと簡単な方法が、最大値を入れる方法です。
例えば、「9999-12-31 23:59:59」をdefault値として設定したり、あるいは格納するようにしておけば、検索などの操作時のSQLは非常に単純にできます。
最初に最大値を入れておき、終了日時が確定した段階で、実際の終了日時で更新すればいいのです。
回答有り難うございます。
なるほど、デフォルト値として入れておけばいいのですね。思いつきませんでした。
これで全てうまく行くことが出来そうです。
分かり易く回答頂きありがとうごさいました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- その他(データベース) 更新クエリをリンクデータベーステーブルに実行し実行時エラー3362固有インデックスに重複する値が含ま 1 2022/09/21 11:44
- MySQL 【MySQL】本当に困っています。詳しい方、ご教授よろしくお願いします。 1 2023/06/03 14:18
- Access(アクセス) アクセス テーブルの空白を変数に置換するボタンが作りたい 4 2022/07/08 11:19
- Access(アクセス) Accessテーブルの結合で別々のテーブルのフィールドを組み合わせて値を出す方法について 2 2022/07/20 19:43
- Ruby pandasでsqlite3にテーブル作成・追加・読み出しでindexの取り扱い方教えてください 5 2023/03/08 09:57
- Access(アクセス) AccessVBAで降順にするテーブル作成クエリを使用して作成したテーブルを削除し同一のテーブル作成 1 2023/01/06 11:17
- Oracle SQL update方法 2 2022/06/22 14:07
- Visual Basic(VBA) ExcelからAccessのテーブルに書き込む時に時間がかかる 1 2022/10/14 20:38
- SQL Server ACCESSで表が作りたく、そのためのSQL文や設定方法を教えてください。 1 2022/08/15 12:28
- MySQL 【MySQL】本当に困っているので、助けてください。よろしくお願いします。 3 2023/06/03 14:24
関連するカテゴリからQ&Aを探す
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
テーブルに存在しない列をselec...
-
SQLでUPSERTを一度に複数行やる...
-
SELECT 文の NULL列は?
-
UPDATE文で既存テーブルへのデ...
-
横並びのコード管理を別テーブ...
-
テーブルを作ろうとしたら。
-
PostgreSQLのanalyzeとは
-
異なるデータベースでのINSERT...
-
reindex と update のデッドロック
-
フィールドの入れ替えはできま...
-
2つのテーブルで引き算 postgres
-
オラクルでいうところのdescとs...
-
プロシージャとトリガー
-
javaでデータベース上のテーブ...
-
Postgresのデータ領域の拡張に...
-
できる人には、簡単な問題だと...
-
PostgreSQLのパーティショニン...
-
SQLServerでの複数テーブルから...
-
パフォーマンス
-
データベースのテーブル一覧を...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
SELECT 文の NULL列は?
-
SQLにて指定日付より前、かつ最...
-
テーブルに存在しない列をselec...
-
SQLでUPSERTを一度に複数行やる...
-
PostgreSQLの断片化の状況を確...
-
単純なselectが遅くなるのです...
-
javaでデータベース上のテーブ...
-
最新レコードを抽出し外部結合...
-
2つのテーブルで引き算 postgres
-
PostgreSQL レコードからアイテ...
-
テーブルにcsvファイルをインポ...
-
VIEWのCOPYってできないんですか?
-
テーブル定義書作成時のIndex付...
-
postgres FILLFACTOR 確認方法
-
reindex と update のデッドロック
-
重複を許すキーの構文がわかり...
-
Postgresqlのレポート機能について
-
Postgresのデータ領域の拡張に...
-
フィールドの入れ替えはできま...
-
DBFluteについて質問です。 環...
おすすめ情報