SQL & PL/SQL :: How To Pass Type Object As A Parameter To Stored Procedure
			May 9, 2012
				I am fairly new to oracle, here's what I am doing.
Create or replace type csc_info as object( source_code   varchar2(10),
                                           Docno         varchar2(10),
                                           Key_value_1   varchar2(10),
                                           Key_value_2   varchar2(10));
[Code]....
I need to test the procedure how do I pass the inputs for the type object csc_info?
	
	View 2 Replies
  
    
		
ADVERTISEMENT
    	
    	
        Mar 28, 2012
        I have created a stored procedure that checks if a file exists and gets a date from the file if it exists. The date is then used as a paramter. See below:
CODEcreate or replace
PROCEDURE                     "P_Load_Stamp" AS
v_exists BOOLEAN; 
v_length NUMBER; 
v_blocksize NUMBER; 
[code]...
The above codes works perfectly and I scheduled it using SQLPLUS as follows:
CODEvariable jobno number;
variable instno number;
begin
select instance_number into :instno from v$instance;
[code]...
My problem is that I need to pass the date from the above procedure as a parameter to another stored procedure. So I modified my code as follows (the parts in red):
CODEcreate or replace
PROCEDURE                     "P_Load_Stamp" (vCTIDATE OUT varchar2) AS 
v_exists BOOLEAN; 
v_length NUMBER; 
[code]...
Now it doesn't strike me as a rights issue since I created it in the schem schema. What could I be doing wrong here?
	View 1 Replies
    View Related
  
    
	
    	
    	
        Oct 26, 2010
        i have a stored procedure whose input parameter is a varchar2 datatype.i created this procedure for an interface and tibco would be calling my procedure by passing input parameters.my problem is when there is a input string with & (ambersand) then its not working.
even i tried to pass the parameter with & in TOAD, it asks me to enter value for string.look at the sample code below which i wrote for testing purpose:
procedure is:
create or replace procedure testproc(p_in in varchar2)
is
begin
null;
end;
i pass parameter as given below:
begin
testproc('abc & def');
end;
if i run above script, it asks me to input some string value as it sees & in the string. attached is the image that shows up in TOAD.  if i run below script it works. but i dont know how many &'s will be there in the input parameter. hence i cant do. and also TIBCO cant modify the input paramter while calling the procedure.
begin
testproc('abc &'||'def');
end;
	View 9 Replies
    View Related
  
    
	
    	
    	
        Mar 29, 2010
        I am trying to execute the procedure from toad, where the type is like an object.How can I do that?
CREATE OR REPLACE TYPE list_t AS TABLE OF list_objtype;
CREATE OR REPLACE TYPE list_objtype AS OBJECT
( Emp_ID            NUMBER(5),
  EMp_Name         VARCHAR2(32 BYTE)
  );
In the following procedure I am calling list_t, but how would i pass the values to it?
PROCEDURE modify_settings
      (  p_List         in        list_t,
         p_info         out       varchar2)
DECLARE 
  p_List  TABLE;
 
[code]...
	View 1 Replies
    View Related
  
    
	
    	
    	
        Mar 26, 2013
        I have search function that takes the input parameters and returns all the matching rows. this is straight forward only. My problem is having multiple types as a input parameter. that is the reason i am not able to pass the input value for these types.
My Input Type table looks like this.
CREATE OR REPLACE TYPE T_T_PARTY_REQUEST_CRITERIA 
AS TABLE OF T_O_PARTY_REQUEST_CRITERIA;
/
CREATE OR REPLACE TYPE T_O_PARTY_REQUEST_CRITERIA 
AS OBJECT 
( 
SYSTEM_IDENTIFER VARCHAR2(50),
PROCESS_TYPE VARCHAR2(50),
[code]........ 
Last two inputs are type again.my question here is how to pass the values for these two T_T_PARTY_KEY_IDENTIFIER and T_T_ADDTN_IDENTIFIER_INFO. I have defined the the last two types following. 
CREATE OR REPLACE TYPE T_T_PARTY_KEY_IDENTIFIER 
AS TABLE OF T_O_PARTY_KEY_IDENTIFIER;
/
CREATE OR REPLACE TYPE T_T_ADDTN_IDENTIFIER_INFO 
AS TABLE OF T_O_ADDTN_IDENTIFIER_INFO;
/
[code].......
I have pasted the query here from my function. when i pass the null as part of input for these 2 types my query is working. otherwise it is saying invalid Identifier.First I tried with first Type. 
I am passing the value as
(PRKYTP.PRTY_KEY_TYP_NM = ITTPRC.PARTY_KEY_IDENTIFIER.PARTY_KEY_TYP_NM OR ITTPRC.PARTY_KEY_IDENTIFIER.PARTY_KEY_TYP_NM = 'ALL' OR ITTPRC.PARTY_KEY_IDENTIFIER.PARTY_KEY_TYP_NM IS NULL); 
Error is Error(34,147): PL/SQL: ORA-00904: "ITTPRC"."PARTY_KEY_IDENTIFIER"."PARTY_KEY_TYP_NM": invalid identifier
SELECT DISTINCT T_O_PARTY_REQUEST_IDENTIFIER(PR.PRTY_RQST_ID) BULK COLLECT INTO T_T_P_R_CRITERIA
FROM TABLE(CAST(I_T_T_PARTY_REQUEST_CRITERIA AS T_T_PARTY_REQUEST_CRITERIA)) ITTPRC,
PRTY_RQST PR 
JOIN BUSN_APPLC BIAP ON BIAP.BUSN_APPLC_ID = PR.BUSN_APPLC_ID 
[code]........
	View 4 Replies
    View Related
  
    
	
    	
    	
        Feb 22, 2011
        i need to pass table as input parameter in stored procedures. during the run time, i am getting error
CREATE OR replace TYPE emp_type IS OBJECT ( 
 id    NUMBER(4), 
 ename VARCHAR2(10));  
 CREATE OR replace TYPE emp_type_tab 
 IS TABLE OF EMP_TYPE;  
 CREATE OR replace PROCEDURE Test_proc (in_emp_type IN EMP_TYPE_TAB) 
AS 
BEGIN 
FOR i IN 1.. in_emp_type.COUNT LOOP 
dbms_output.Put_line(in_emp_type.Id(i)); 
END LOOP; 
END; 
/
	View 10 Replies
    View Related
  
    
	
    	
    	
        Jul 18, 2012
        Does it possible to pass object (or) table as an argument to a remote procedure?
	View 2 Replies
    View Related
  
    
	
    	
    	
        Oct 3, 2010
        I am  passing a string from vb.net through oracle store procedure. String consists of varchar values for eg '123456;I|N,2424424;O|A'. But how can i call these string values into array using oracle stored procedure? After getting these values into array , i wanted to loop through these values.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Oct 19, 2011
        I have the following error when I try to pass a Procedure parameter carrying db_link name to a stored procedure:
SQL> CREATE OR REPLACE PROCEDURE AFESD.P_DM_VCONTRACT_ITEM (CON_CONNECTION VARCHAR2)
  2  IS
  3  T_CONNECTION VARCHAR2(50);
  4  T_SQL VARCHAR2(500);
  5  BEGIN
  6  T_CONNECTION := 'X_DM_TEST@' || CON_CONNECTION;
[code]....
The insert statement succeeds when I try to run DBMS_OUTPUT.put_line output.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jun 2, 2010
        I am trying to pass a PL/SQL table as a parameter to a procedure and then using that table, update the records, but I am getting an error like:
ORA-06550: line 30, column 10:
PLS-00306: wrong number or types of arguments in call to 'UPDATE_STATUS'
Find the code below:
CREATE TABLE test_pl(empno VARCHAR2(20), empname VARCHAR2(40), empsts VARCHAR2(10));
INSERT INTO test_pl
     VALUES ('0001', 'A', 'Y');
INSERT INTO test_pl
     VALUES ('0002', 'B', 'N');
INSERT INTO test_pl
     VALUES ('0003', 'C', 'Y');
INSERT INTO test_pl
     VALUES ('0004', 'D', 'Y');
[code]....
	View 4 Replies
    View Related
  
    
	
    	
    	
        Sep 1, 2010
        I want to pass a table as a parameter to a procedure.
As an example:
TYPE my_tab IS TABLE OF my_rec INDEX BY BINARY_INTEGER;
However, I want to give this parameter a default of null... is this possible?
procedure myproc(p_param1 in varchar2, p_tab in my_tab default null)
	View 11 Replies
    View Related
  
    
	
    	
    	
        Feb 26, 2012
        I am trying to pass many characters to the in mode parameter using procedure , but i am getting the below error. 
ORA-06550: 
PLS-00172: string literal too long
CREATE TABLE USR_DETAILS 
(
LOAD_ID     NUMBER                            NOT NULL,
LOAD_DATE   DATE,
USER_VALUE  VARCHAR2(4000 BYTE),
USERID      VARCHAR2(4000 BYTE)
)
insert into user_details values('1','2/10/2011','PROD1','USER1');
insert into user_details values('2','2/10/2011','PROD2','USER2');
[code]......
I have written the code as below...
Procedure concept :
Here i will seperate the strings(input parameters) using comma(,)  symbol . Here users may pass more than 5000 characters to single in mode parameter, so i have  tried with clob datatype but no luck.
CREATE OR REPLACE procedure user_details_proc (user_value1  IN varchar2,
user_value2 IN varchar2,
user_value3 IN varchar2,
user_value4 IN varchar2,
user_value5 IN varchar2,
userid IN varchar2
 ) as
[code].......  
	View 2 Replies
    View Related
  
    
	
    	
    	
        Mar 29, 2013
        I have an Type-object typeObj1 that consists another Type-object typeObj2. this def has another Type-object typeObj3. how to access variable declared inside typeObj3. I have syntax below for each Type.
CREATE OR REPLACE TYPE typeObj1
AS OBJECT 
   ( 
      SYSTEM_IDENTIFER                    VARCHAR2(50),
      PROCESS_TYPE                          VARCHAR2(50),
      abc                                            typeObj2
      
   )
/
[Code]...
/I have tried to access the type-object in where clause in following way
FROM TABLE(CAST(I_typeObj1 AS typeObj1)) ITTPRC,
......
Where
.......
AND (ADDKEY.ADDTN_INFO_KEY_TYP_NM IN (SELECT ADDTN_INFO_KEY_TYP_NM FROM TABLE(ITTPRC.abc)))
AND (ADTINF.ADDTN_RQST_TYP_VAL_DT  IN (SELECT ADDTN_RQST_VAL_DT FROM TABLE(     ITTPRC.def)) OR ITTPRC.def IS NULL )
AND (ADTINF.ADDTN_RQST_TYP_VAL_NUM  IN (SELECT ADDTN_RQST_VAL_NUM FROM TABLE( ITTPRC.def)) OR ITTPRC.def IS NULL )
AND (ADTINF.ADDTN_RQST_TYP_VALUE  IN (SELECT ADDTN_RQST_VALUE FROM TABLE( ITTPRC.def)) OR ITTPRC.def IS NULL ) 
 In this way i am able to access the variable inside typeObj3. But problem is i am getting error "ORA-01427 single-row subquery returns more than one row" when i pass more that one typeObj2.
I passed the values like this in proc execution.
T_T_A_I_V  :=  typeObj3('asdasd',NULL,NULL),
                       typeObj3('String654',NULL,NULL),
                       typeObj3('abcdef',NULL,NULL));                                     
T_T_A_I_I  :=  typeObj2('CampusCode',T_T_A_I_V),
                          typeObj2('PlanNumber',T_T_A_I_V); 
What i have done is removed typeObj3 from typeObj2, variables defined in typeObj3 are added in typeObj2 then i got ride of above error. is it correct
	View 4 Replies
    View Related
  
    
	
    	
    	
        May 23, 2012
        Can i use lexical parameter within my procedure 
select '' employee_no, ptdv.fiscal_year, ptdv.trans_month, ptdv.location_code, ptdv.acc_code,ptdv.acc_desc,sum(ptdv.EARNING)-sum(ptdv.DEDUCTION) debit,0 credit,1 tag
from pr_trans_dtl_v ptdv
where ptdv.trans_month=nvl(mtrans_month, ptdv.trans_month)
[code].......   
see the highlighted row. can i use and ptdv.trans_type_row  in &vtype instead of and ptdv.trans_type_row  in ('R','A')
where the vtype is varchar2(100) and vtype:='(''R'',''A'')';
	View 1 Replies
    View Related
  
    
	
    	
    	
        Jun 17, 2010
        I have created a procedure like this
CREATE OR REPLACE PROCEDURE SCOTT.GetEmpList(p_recordset OUT SYS_REFCURSOR) AS
BEGIN
OPEN p_recordset FOR
SELECT * FROM scott.emp
WHERE deptno=10;
END GetEmpList;
Now i would like to execute this procedure in sqlplus which will display the following:
EMPNO ENAME   JOB      MGR   HIREDATE   SAL  COMM DEPTNO
7782  CLARK   MANAGER  7839  6/9/1981   2450      10
7839  KING    PRESIDENT      11/17/1981 5000      10
7934  MILLER  CLERK    7782  1/23/1982  1300      10
	View 5 Replies
    View Related
  
    
	
    	
    	
        Mar 26, 2012
        I have need to know the best (least expensive) way to create a stored procedure that creates a new records in a table using a sequence and return the primary key (sequence value) for this inserted record:
CREATE TABLE TEST_A (SERIAL NUMBER PRIMARY KEY, NAME VARCHAR2(20));
CREATE SEQUENCE SEQ_TESTA_PK START WITH 1
NOCACHE
NOCYCLE;
CREATE OR REPLACE TRIGGER TRG_TESTA_PK 
BEFORE  INSERT ON TEST_A
[code]....
	View 8 Replies
    View Related
  
    
	
    	
    	
        May 15, 2011
        I'm creating a stored procedure wherein I'm the field wherein I will use for date input parameter is having a datetime format.
The format that we need for user's to input is 'DD-MON-YYYY' (without the minutes and seconds.)
how should I proceed with the creation of stored procedure for this?
	View 2 Replies
    View Related
  
    
	
    	
    	
        Jul 14, 2011
        how to create stored procedure with an array as an output parameter.I mean when we need to return multiple rows...
	View 7 Replies
    View Related
  
    
	
    	
    	
        May 31, 2011
        I have one stored proc with three in parameters as
number, varchar and table of number
what statement I need to write in pl/sql to execute it ...
execute getdetails(1,'xyz', ????????????)
	View 5 Replies
    View Related
  
    
	
    	
    	
        Nov 7, 2013
        i have created a package & stored procedure which is working fine when i am passing single value to my package or stored procedure. But what approach i should  take if i have to pass multiple values (ArrayList) like (from eg empid like I1001,I1002,I1003,I1004,...) in my input parameter . I am using C# & Oracle
 CREATE OR REPLACE PACKAGE PKG_x AS type t_cursor is ref cursor;
procedure Proc(cur_x out t_cursor,
param_emp in varchar2 DEFAULT NULL);
END PACKAGE PKG_x;
[Code].....
	View 2 Replies
    View Related
  
    
	
    	
    	
        Jun 22, 2012
        I have a problem with passing procedure name dynamically with record type i/p parameter..I'm not attaching any insert/create table statements, as I'm unsure of forming the sql statement dynamically..
CREATE OR REPLACE PACKAGE med_order_pkg AS
 TYPE deid_med_order_typ IS RECORD(....)
  L_deid_med_order_typ  deid_med_order_typ;
  PROCEDURE RULE_MASTER_PRC (P_IN_RULE IN deid_med_order_typ);
END;
[code]....
From the above, I need to execute a procedure with record type as i/p parameter..V_SQL should form the statement & execute another procedure which comes into the variable V_MSG_PROC .I'm having difficuly in forming the statement...(I did it by hard-coding the procedure with parameter in the next line which is commented out & it works...So how can I modify V_SQL in the above statement?
	View 3 Replies
    View Related
  
    
	
    	
    	
        Feb 6, 2012
        This procedure is not working properly.
create or replace procedure bank_search_sp
(
p_tablename in varchar2,
p_searchname in varchar2,
p_bankcode out varchar2,
p_bankname out varchar2,
p_dist_code out number
)
as
v_tem varchar2(5000);
begin
v_tem :='select bankcode,bankname,dist_code from ' || UPPER (p_tablename) || '
where bankname like '''|| p_searchname||'';
execute immediate v_tem into p_bankcode,p_bankname,p_dist_code using p_searchname ;
commit;
end bank_search_sp;
the Procedure is getting created but i dont know what actually happens when it was executed ,This is the error shown..ORA-01756: quoted string not properly terminated
ORA-06512: at "PENSIONS.BANK_SEARCH_SP", line 14
ORA-06512: at line 1
	View 1 Replies
    View Related
  
    
	
    	
    	
        Mar 8, 2013
        I have created the below types and oracle objects.
create or replace type T_EMA_NP_SETDEL_RESP_REC as object
(
respCode             number,
respDesc             varchar2(255)
)
create or replace type T_EMA_NP_RANGE_LNPTICKET_TAB AS TABLE OF T_EMA_NP_RANGE_LNPTICKET_REC
create or replace type T_RANGE_TICKET_TAB AS TABLE OF T_RANGE_TICKET_REC
The following types are created in the Package specification
type t_resp_rec IS RECORD
(
resp_code number,
resp_desc varchar2(255)
);
--
subtype t_ema_lnpticket is T186_IN_REQ_PARAMETER.T186_EMA_LNPTICKET%TYPE; -- Number
type t_ema_lnpticket_tab is table of t_ema_lnpticket index by binary_integer;
I have the following two procedures
PROCEDURE getEMAReturnResponse(
p_in_call_request_id        IN number,
p_ema_resp_rec              IN t_ema_np_setdel_resp_rec,
p_ema_range_lnpticket_tab   IN t_ema_np_range_lnpticket_tab,
p_endof_event               IN varchar)
PROCEDURE Return_Response(p_in_call_request_id  IN number,
p_ema_resp_rec        IN t_ema_resp_rec,
p_ema_lnpticket_tab   IN t_ema_lnpticket_tab,
p_endof_event         IN varchar2)
getEMAReturnResponse Procedure: 
Accessed by Java application to pass the values. Should call the Return_Response procedure and pass the values received from Java.
Return_Response Procedure 
 The p_ema_lnpticket_tab is a sort of array that can have multiple values. Please see the example of values.  Has all the business rules and validation that should be adhered.
Example of Vaules
p_in_call_request_id  = 1
p_ema_resp_rec        = 12345, 'Operation Failed'
p_ema_lnpticket_tab   = (1,2,4,5)
p_endof_event         = Y
	View 2 Replies
    View Related
  
    
	
    	
    	
        Mar 8, 2013
        I have created the below types and oracle objects.
create or replace type T_SETDEL_RESP_REC as object
(
respCode number,
respDesc varchar2(255)
)
--
create or replace type T_EMA_NP_RANGE_LNPTICKET_REC as object
(
ticket number
)
create or replace type T_RANGE_TICKET_TAB AS TABLE OF T_RANGE_TICKET_REC
The following type is created in the Package specification
type t_resp_rec IS RECORD
(
resp_code number,
resp_desc varchar2(255)
);
I have the following two procedures
Procedure getResponse(p_call_request_id IN number, p_resp_rec IN t_setdel_resp_rec,
p_range_ticket_tab IN t_range_icket_tab, p_endof_event IN varchar)
PROCEDURE ProcessResponse(p_call_request_id IN number, p_resp_rec IN t_resp_rec,
p_ticket_tab IN t_ticket_tab, p_endof_event IN varchar2)
The get Response procedure is a wrapper procedure exposed to Java to pass values. The Process Response procedure is a main procedure where all logics and business rules are handled.
The Problem is: 
How can I pass the values from get Response procedure to Process Response procedure. So that rules and validations are applied. Please note the p_ticket_tab may have many ticket numbers corresponding to p_call_request_id.
Values E.g. :
p_call_request_id = 1
p_resp_rec (1234, 'Error found')
p_range_ticket_tab (1,2,3,4,5)
p_endof_event = 'Y'
	View 7 Replies
    View Related
  
    
	
    	
    	
        Mar 26, 2013
        I've the following function returning OBJECT type. how to call this function
CREATE OR REPLACE TYPE GET_EMP_OBJ is object
   ( emp_name varchar2(50) ,
     mgr_id   number,
     dept_id  number
   );
[Code]...
The above function got created successfully.  And i'm confused how to call this functions. I tried like below but didn't work
DECLARE
  t_emp_info_1  GET_EMP_OBJ ;
BEGIN
   t_emp_info_1 := get_emp(7566) ;
   for i in 1..t_emp_info_1.COUNT 
      LOOP
         DBMS_OUTPUT.put_line ('Values are'||i.emp_name ) ;
     END LOOP;
END;  
	View 7 Replies
    View Related
  
    
	
    	
    	
        Mar 7, 2013
        I have been creating lot many threads around the same problem, however i thought i knew but realized I do not know or else do not know how to. I have created object type with an attribute READINGVALUE NUMBER(21,6)...How can i use type attribute on this object while declaring variable.....can we use type attribute on NESTED TABLES, similar to the db tables? 
example 
CREATE TYPE READING AS OBJECT(READINGVALUE NUMBER(21,6));
CREATE TABLE INTERVALREADINGS OF TYPE READING;
	View 5 Replies
    View Related
  
    
	
    	
    	
        Aug 17, 2013
        I want to return the output of this query using one OUT parameter from the procedure using RECORD type or OBJECT type.
SELECT empno,ename,sal FROM emp WHERE deptno=30;
Let us assume the query is returning 50 records.
I want to send those 50 records to OUT parameter using record type or object type.
	View 20 Replies
    View Related
  
    
	
    	
    	
        Nov 16, 2012
        How to pass parameter in a view.
create or replace view spic_bags as
select distinct(a.item_code) Material_Code,a.uom,
(case when a.card_code = '60'  then 
case when a.ccn <> '091' then 
[code]........       
in this above view i have hardcoded dates, well how to pass parameter for this view without hardcoding? here i need to pass the date as a parameter from a select query to view the data from the above view!
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jun 22, 2010
        In a procedure i need to pass date parameter, to check how to do this. I create a simple procedure, but it giving 
PLS-00049: Bad Bind Variable 'FD'
PLS-00049: Bad Bind Variable 'TD'
How to resolve .......
CREATE PROCEDURE pass_date_parameter
AS
   fd    VARCHAR2 (10)  DEFAULT '01-01-2010';
   td    VARCHAR2 (10)  DEFAULT '01-06-2010';
   ffd   VARCHAR2 (10)  DEFAULT '01-01-2010';
   ttd   VARCHAR2 (10)  DEFAULT '01-06-2010';
[Code]....
	View 19 Replies
    View Related
  
    
	
    	
    	
        Mar 5, 2010
        i had a chart developed by graphics builder in which I am passing one parameter(ie year) and displaying the chart.Now i want to pass two parameter into chart.How to do this here i have attached my chart view and procedure which executes and display the chart from forms.
coding when button pressed
PROCEDURE CHART_DISPLAY IS
pl_id ParamList;
pl_name VARCHAR2(100) := 'tempdata';
[Code]....
In the above procedure i had one parameter directly am passing value of year '2009' now i want to pass two parameter like between 'year1' and 'year2' for getting chart between two years.
	View 1 Replies
    View Related