🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
INSERT

INSERTとは、行を追加する、コンピュータのデータベース言語SQLにおけるデータ操作言語(DML)ステートメントの1つである

Oracle

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

Null

Nullとは、プログラミング言語やデータベースにおけるデータ表現の一種です。コンテキストによって"空"もしくは"長さ0の文字列"、”未知・不明”を意味します。

SQL

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

Q&A

解決済

3回答

2381閲覧

OracleのSELECT INSERTでファンクションの値をセットしたい(いまはNULLになってしまう)

akiras

総合スコア8

INSERT

INSERTとは、行を追加する、コンピュータのデータベース言語SQLにおけるデータ操作言語(DML)ステートメントの1つである

Oracle

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

Null

Nullとは、プログラミング言語やデータベースにおけるデータ表現の一種です。コンテキストによって"空"もしくは"長さ0の文字列"、”未知・不明”を意味します。

SQL

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

0グッド

0クリップ

投稿2019/10/04 02:01

概要

・OracleのSELECT INSERTでファンクションの戻り値をセットしたい

問題点

・現在はファンクションの戻り値だけがNULLになってしまう
・INSERTをコメントして、SELECTだけだと戻り値が取得でる
・この場合ループで都度INSERTではなく、1度だけのINSERTはできないのでしょうか?

ご教授願います。

ファンクション

・社員番号をもとに基本給を2倍した値を返す

環境

・Oracle11g

SELECT文

html

1SELECT 2 EMP_NO 3 ,EMP_NAME 4 ,F_GET_BONUS(EMP_NO) AS BONUS   -- ファンクション 5 ,'2019/12/10' AS SUPPLY_DAY 6FROM EMP_TBL 7WHERE EMP_NO IN ( 8 SELECT EMP_NO FROM TARGET_TBL 9 WHERE POSITION=1 10); 11

※社員ごとにボーナス(BONUS)が取得できます

SELECT INSERT

html

1INSERT INTO EMP_TBL 2SELECT 3 EMP_NO 4 ,EMP_NAME 5 ,F_GET_BONUS(EMP_NO) AS BONUS   -- ファンクション 6 ,'2019/12/10' AS SUPPLY_DAY 7FROM EMP_TBL 8WHERE EMP_NO IN ( 9 SELECT EMP_NO FROM TARGET_TBL 10 WHERE POSITION=1 11);

ORA-01400: BONUSにNULLは挿入できません。

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

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

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

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

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

guest

回答3

0

自己解決

ファンクションをやめて副問い合わせにしたら、登録できました。
回答ありがとうございました。

INSERT INTO EMP_TBL
SELECT
EMP_NO
,EMP_NAME
-- ,F_GET_BONUS(EMP_NO) AS BONUS    -- ファンクション
,(SELECT ~ FROM xxTBL WHERE EMP_NO=EMP_NO)  -- 副問い合わせ
,'2019/12/10' AS SUPPLY_DAY
FROM EMP_TBL
WHERE EMP_NO IN (
SELECT EMP_NO FROM TARGET_TBL
WHERE POSITION=1
);

投稿2019/10/04 02:44

akiras

総合スコア8

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

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

0

F_GET_BONUS が NULL を返しているだけでは?
F_GET_BONUS 内容を Oracle DDL取得 を参考に取得し、質問に追記しては?

投稿2019/10/04 02:31

Orlofsky

総合スコア16417

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

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

akiras

2019/10/04 02:41

回答ありがとうございます。 SELECT文だけだと、戻り値が取得できています。
Orlofsky

2019/10/04 03:00

SELECT結果やCREATE FUNCTIONを提示しないので質問者本人にしか理解できません。 きちんとSQL, PL/SQLを勉強していないから中途半端な質問しか書けないのでしょう。次の質問から使っているテーブルのCREATE TABLE文、現行の存在するデータのINSERT文を数行ずつとCREATE FUNCTION文も質問に載せてください。 なお、日時はDATE型を使った方が便利なのでOracle SQLはDATE型をサポートしています。
guest

0

F_GET_BONUS が NULL を返す場合があるのでは?

条件式に
AND F_GET_BONUS(EMP_NO) IS NULL
を付加して実行してみてください。

投稿2019/10/04 02:20

KOZ6.0

総合スコア2707

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

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

akiras

2019/10/04 02:41

回答ありがとうございます。 条件式に入れたけど、同じエラーでした。
KOZ6.0

2019/10/04 02:44

INSERT 文に入れたのですね。 INSERT なしの SQL に条件式を入れたら何件か返ってくると思いますよ。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問