![](/img/trans.png)
[英]ORA-06550: line 1, column 7: PLS-00306: wrong number or types of arguments in call
[英]Caused by: java.sql.SQLException: ORA-06550: line 1, column 7: PLS-00306: wrong number or types of arguments in call to 'PR_SP_FAHMI'
我有 java 文件,該文件用於使用 SimpleJdbc 執行存儲過程,如下面的代碼:
@Transactional(propagation = Propagation.REQUIRED, rollbackFor = {SQLException.class, Exception.class })
public void executeSPForInsertData(DataSource ds,String procedureName,Map<String, Object> inputParameter){
//PARAMS.PKG_PARA_UPLD_VAL.PR_SP_FAHMI
String[] inParam = inputParameter.keySet().toArray(new String[0]);
SqlParameter[] in = new SqlParameter[inParam.length];
String[] buff = new String[inParam.length * 2];
SimpleJdbcCall jdbcCall = new SimpleJdbcCall(paramsDataSourceBean)
.withProcedureName(procedureName)
.withoutProcedureColumnMetaDataAccess()
.useInParameterNames(buff).declareParameters(in);
String[] path = procedureName.split(".");
if (path.length >= 2) {
jdbcCall.withSchemaName(path[0]);
jdbcCall.withCatalogName(path[1]);
jdbcCall.withProcedureName(path[2]);
}
Map<String,Object> outputParameter = jdbcCall.execute(inputParameter);
}
這是我的存儲過程
PROCEDURE PR_SP_FAHMI (P_T_TABLE_UPLD_EXCEL IN PARAMS.EXCEL)
is
P_LOGID VARCHAR2(255);
BEGIN
BEGIN
INSERT INTO PARAMS.EMPTY
SELECT
C.PARA_OBJT_GROUP ,
C.PARA_OBJT_CODE ,
C.PARA_PROD_MATRIX_ID ,
C.PARA_PROD_CHANNEL_ID ,
C.PARA_PROD_SALES_GROUP_ID ,
C.PARA_CUST_GROUP ,
C.PARA_SLS_THROUGH_ID ,
C.ACTIVE
FROM TABLE(P_T_TABLE_UPLD_EXCEL) C;
EXCEPTION
WHEN NO_DATA_FOUND THEN
NULL;
WHEN OTHERS THEN
RAISE_APPLICATION_ERROR(-20001, 'ERROR-' || SQLERRM);
END;
END PR_SP_FAHMI;
這是聲明類型 excel
CREATE OR REPLACE TYPE EXCEL AS TABLE OF PARAMS.T_OBJECT_FROM_EXCEL
這是聲明類型 T_OBJECT_FROM_EXCEL
CREATE OR REPLACE TYPE "T_OBJECT_FROM_EXCEL" FORCE AS OBJECT (
para_objt_group VARCHAR2(3),
para_objt_code VARCHAR2(3),
para_prod_matrix_id VARCHAR2(5),
para_prod_channel_id VARCHAR2(3),
para_prod_sales_group_id VARCHAR2(5),
para_cust_group VARCHAR2(3),
para_sls_through_id VARCHAR2(2),
active NUMBER(1)
)
當我運行代碼時,我有這個錯誤
Caused by: java.sql.SQLException: ORA-06550: line 1, column 7:
PLS-00306: wrong number or types of arguments in call to 'PR_SP_FAHMI'
ORA-06550: line 1, column 7:
PL/SQL: Statement ignored
我在互聯網上搜索通過查看類似錯誤來解決這個問題,但仍然無法解決我的問題。
要使用 Spring 調用 Oracle 存儲過程,該存儲過程采用類型為 object 表的參數的參數,需要做幾件事。
Firstly, you need to create an Java class that corresponds to the Oracle object type T_OBJECT_FROM_EXCEL
. 它需要實現SQLData接口。 它將如下所示(請隨意更改字段名稱):
import java.sql.SQLData;
import java.sql.SQLException;
import java.sql.SQLInput;
import java.sql.SQLOutput;
public class ExcelRow implements SQLData {
private String objectGroup;
private String objectCode;
private String prodMatrixId;
private String prodChannelId;
private String prodSalesGroupId;
private String prodCustGroup;
private String slsThroughId;
private boolean active;
// ... constructor, getters and setters omitted ...
@Override
public String getSQLTypeName() {
return "PARAMS.T_OBJECT_FROM_EXCEL";
}
@Override
public void readSQL(SQLInput sqlInput, String typeName) throws SQLException {
throw new SQLException("This has not been implemented");
}
@Override
public void writeSQL(SQLOutput sqlOutput) throws SQLException {
sqlOutput.writeString(this.objectGroup);
sqlOutput.writeString(this.objectCode);
sqlOutput.writeString(this.prodMatrixId);
sqlOutput.writeString(this.prodChannelId);
sqlOutput.writeString(this.prodSalesGroupId);
sqlOutput.writeString(this.prodCustGroup);
sqlOutput.writeString(this.slsThroughId);
sqlOutput.writeInt(this.active ? 1 : 0);
}
}
SQLData 接口具有三個方法, getSQLTypeName()
、 readSQL()
和writeSQL()
。 getSQLTypeName()
returns the name of the Oracle type we are mapping to, and writeSQL()
writes the data in an ExcelRow
object to the given output object sqlOutput
. 我們寫入的字段的順序必須與它們在T_OBJECT_FROM_EXCEL
中聲明的順序相匹配。 readSQL()
用於將從數據庫返回的T_OBJECT_FROM_EXCEL
object 轉換為ExcelRow
,但我們只對將值發送到數據庫感興趣,而不是從數據庫接收它們,因此為簡潔起見,我剛剛實現它以拋出一個例外。
其次,您需要調整調用存儲過程的代碼。 您的方法executeSPForInsertData
似乎有些通用,因為它需要一個存儲過程和任意 map 參數。 由於 table 類型參數,這個存儲過程以通用方式調用有點尷尬,所以我們將編寫一個專門用於這個存儲過程調用的方法:
public void executeSPForInsertData(DataSource ds, ExcelRow[] excelRows){
String parameterName = "P_T_TABLE_UPLD_EXCEL";
SqlParameter[] parameterTypes = { new SqlParameter(parameterName, OracleTypes.ARRAY, "PARAMS.EXCEL") };
Map<String, Object> parameters =
Collections.singletonMap(parameterName, new SqlArrayValue<>(excelRows));
SimpleJdbcCall jdbcCall = new SimpleJdbcCall(ds)
.withSchemaName("PARAMS")
.withCatalogName("PKG_PARA_UPLD_VAL")
.withProcedureName("PR_SP_FAHMI")
.withoutProcedureColumnMetaDataAccess()
.declareParameters(parameterTypes);
jdbcCall.execute(parameters);
}
我們首先聲明參數類型:有一個參數,它是一個數組,其 Oracle 類型在PARAMS
模式中為EXCEL
。 然后我們聲明參數值,使用SqlArrayValue
來包裝我們傳入的ExcelRow
數組。最后我們設置存儲過程調用,然后調用它。 由於參數名稱被使用了兩次,我把它放在一個局部變量中。
我對 Oracle 18c XE 數據庫進行了快速測試,它工作正常,因為我可以調用這個存儲過程並將數據寫入數據庫。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.