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

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

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

Oracle Databaseは、米オラクルが開発・販売を行うリレーショナルデータベース管理システムです。

Oracle

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

PL/SQL

PL/SQL (Procedural Language/Structured Query Language) はOracle CorporationによるSQL(非手続き型言語)を手続き型言語に拡張させるために開発されたプログラミング言語です。

SQL

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

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

Q&A

解決済

1回答

8547閲覧

SQLPLUSでORA-06550エラー

退会済みユーザー

退会済みユーザー

総合スコア0

Oracle Database

Oracle Databaseは、米オラクルが開発・販売を行うリレーショナルデータベース管理システムです。

Oracle

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

PL/SQL

PL/SQL (Procedural Language/Structured Query Language) はOracle CorporationによるSQL(非手続き型言語)を手続き型言語に拡張させるために開発されたプログラミング言語です。

SQL

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

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

0グッド

0クリップ

投稿2020/12/03 07:34

問題点

plsqlのパッケージプログラムが以下のエラーを吐いていて解決できません。

sqlplus

1execute unk01.cp1 2BEGIN unk01.cp1; END; 3 4 * 5行1でエラーが発生しました。: 6ORA-06550: 行1、列7: 7PLS-00306: 'CP1'の呼出しで、引数の数または型が正しくありません。 8ORA-06550: 行1、列7: 9PL/SQL: Statement ignored

ソースコード

以下ソースです。

仕様部

SET SERVEROUT ON CREATE OR REPLACE PACKAGE unk01 IS FUNCTION cp1(EMPNO IN NUMBER) RETURN NUMBER; END; /

宣言部

SET SERVEROUT ON CREATE OR REPLACE PACKAGE BODY unk01 IS FUNCTION cp1(EMPNO IN NUMBER)RETURN NUMBER IS CURSOR cursor IS SELECT EMPNO FROM emp; EMPS cursor%ROWTYPE; BEGIN open cursor; LOOP FETCH cursor INTO EMPS; EXIT WHEN cursor%NOTFOUND; INSERT INTO EMP_DEPT(EMPNO)VALUES(EMPS.EMPNO); END LOOP; close cursor; EXCEPTION END cp1; END unk01; /

よろしくお願いします。

環境

Oracle12c standerd
sqlplus console

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

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

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

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

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

guest

回答1

0

ベストアンサー

execute unk01.cp1だとパラメータが無いからエラーです。
execute unk01.cp1(123)のようにパラメータを指定して下さい。

投稿2020/12/03 08:39

sazi

総合スコア25327

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

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

退会済みユーザー

退会済みユーザー

2020/12/03 08:50

回答ありがとうございます。ご指摘の通りにパラメータを追加したのですが以下のエラーに切り替わりました execute unk01.cp1(1) ORA-06550: 行1、列7: PLS-00221: 'CP1'がプロシージャではないか、または未定義です。 ORA-06550: 行1、列7: PL/SQL: Statement ignored
sazi

2020/12/03 08:58 編集

実行しているユーザーのカレントスキーマーがパッケージの登録されているスキーマーと同じか確認して下さい。 若しくは権限かもしれません。 ログインしているユーザーでパッケージの登録も行っていればそのようなエラーにはなりません。
退会済みユーザー

退会済みユーザー

2020/12/04 05:48

SYSユーザではなく新規にユーザを作ってDBA権限で諸々作成し直したら実行できました。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問