SQL & PL/SQL :: Invalid Cursor Error In Procedure 
			Feb 2, 2011
				I have this stored procedure as part of package. 
PROCEDURE XCOM_X060_UPDATEOHBFAILURE( in_CALL_ID                    IN    NUMBER,
                                      in_SPLY_REORD_NO              IN    CHAR,
                                      in_OHB_QTY_CARTONS            IN    NUMBER,
                                      in_OHB_QTY_UNITS              IN    NUMBER,
                                      in_SPLY_TOT_OHB_QTY           IN    NUMBER,
                                      in_OHB_INPUT_CTNS_MIN         IN    NUMBER,
                                      in_OHB_INPUT_CTNS_MAX         IN    NUMBER,
                                      in_UNITS_PER_CARTON           IN    NUMBER,
                                      in_OHB_INPUT_UNIT_CONSTANT    IN    NUMBER,
                                      in_TOTAL_CARTONS              IN    NUMBER,
                                      out_ALLOW_OHB_INPUT_FLAG      OUT   CHAR,
                                      out_ERR_CODE                  OUT   NUMBER,
                                      out_ERR_MESSAGE               OUT   VARCHAR2)
When the stored procedure is executed it is throwing following exception OTHERS EXCEPTION in XCOM_X060_UPDATEOHBFAILURE - SQL -1001  SQLERRM: ORA-01001: invalid cursor
Here is the execution script 
DECLARE 
  IN_CALL_ID NUMBER;
  IN_SPLY_REORD_NO VARCHAR2(32767);
  IN_OHB_QTY_CARTONS NUMBER;
  IN_OHB_QTY_UNITS NUMBER;
  IN_SPLY_TOT_OHB_QTY NUMBER;
  IN_OHB_INPUT_CTNS_MIN NUMBER;
 [code]...
There is no cursor used in the procedure. It just inserts records in the table for given input values. 
	
	View 10 Replies
  
    
		
ADVERTISEMENT
    	
    	
        Jan 3, 2011
        CREATE OR REPLACE PROCEDURE test
IS
CURSOR cusers IS SELECT user_name, user_date FROM users;
uname users.user_name%TYPE;
udate users.user_date%TYPE;
BEGIN
OPEN cusers;
[code].....
When I try to execute this procedure I get following error:
ORA-00900: invalid SQL statement
Compilation of procedure is successful.
SQL code for creating the USERS table is here:
CREATE TABLE  "USERS" 
   ("USER_ID" NUMBER(10,0) NOT NULL ENABLE, 
"USER_NAME" VARCHAR2(50) NOT NULL ENABLE, 
"USER_EMAIL" VARCHAR2(50) NOT NULL ENABLE, 
"USER_PASS" VARCHAR2(50) NOT NULL ENABLE, 
"USER_DATE" DATE NOT NULL ENABLE, 
 CONSTRAINT "USERS_PK" PRIMARY KEY ("USER_ID") ENABLE
   )
	View 3 Replies
    View Related
  
    
	
    	
    	
        Dec 2, 2010
        procedure vieworderstatus(in_CALL_ID                 IN  NUMBER ,
                          in_DAYS_OF_HISTORY         in  number ,
                          out_SUPLY_REORDR_STATUS_LST OUT supplyreordrlist ,
                          out_ERR_CODE               OUT NUMBER,
                          out_ERR_MESSAGE            out varchar2);
This procedure takes retrievs cust_id for given input call_id. The procedure then retrieves order information for that customer and returns using the out ref cursor. I need to test the scenario where the user passes invalid call_id. 
The following query returns no data for call_id = 12345 ( invalid call_id)
select fk_cust_id into v_cust_id 
from xcom_call 
where call_id = in_CALL_ID;
in such cases; I just need to return null ref cursor and log the error but right now when I pass invalid call_id ; I am getting "invalid cursor" error.How do I handle this ?
	View 35 Replies
    View Related
  
    
	
    	
    	
        Apr 25, 2012
        i have created a procedure to open a query using a reference sys_refcursor as output parameter. i referenced the cursor in a pl/sql and is working correctly. however it throws error "ORA-01001: invalid cursor ORA-01403: no data found" when use on the oracle forms builder.
create or replace procedure mrch.prc_proj_list (p_add_clause in varchar2, p_rec_set out sys_refcursor) as
begin
    Open p_rec_set for
    'Select mp2.REGION                                         region,    '||
    '       mp2.ID                                             proj_id,   '||
    '       mppm2.PHASE                                        phase,     '||
    '       mm2.muni                                           muni_id,   '||
    '       mm2.MUNINAME                                       muni_name, '||
    '       nvl((select Sum(ma.AMOUNT) From MRCH.MRC_AGREEMENT ma         '||
    '             Where ma.PROJECT_ID = mp2.ID                            '||
    '               And ma.PHASE      = mppm2.phase                       '||
    '               And ma.MUNI       = mm2.MUNI),0) agreement,           '||
    '       nvl((Select Sum(NVL(ma.GREEN_BOOK_AMOUNT,0) + NVL(ma.GB_ADJUST,0)) From MRCH.MRC_ALLOCATION ma '||
   [code]....
	View 3 Replies
    View Related
  
    
	
    	
    	
        May 12, 2010
        I want run a procedure from a easy sql select.I have write this code to run this procedure, but response with a oracle error:
select [procedure_name](:data1, :data2) as test from dual
the oracle error is this:
ORA-00904: "PROCEDURENAME": invalid identifier
	View 12 Replies
    View Related
  
    
	
    	
    	
        Feb 4, 2012
        Here is the code I am using:
CREATE OR REPLACE
PROCEDURE CUBE_VIEW (VAR_DT IN VARCHAR2 DEFAULT '')
AUTHID CURRENT_USER
AS
START_DATE NUMBER;
END_DATE NUMBER;
VAR DATE;
BEGIN
IF VAR_DT IS NULL THEN
[code]....
The code complies successfully but when I am executing the code, here is the error I get. The code works successfully when I manually insert the values (as done in the commented out statement) but when use it from variable, it gives me error. 
Connecting to the database LocalEnvironment.
ORA-00904: "END_DATE": invalid identifier
ORA-06512: at "TESTING.CUBE_VIEW", line 18
ORA-06512: at line 6
START DATE IS 90301
END DATE IS 111201
Process exited.
Disconnecting from the database LocalEnvironment.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Aug 3, 2010
        Oracle Database 11g Enterprise Edition Release 11.1.0.6.0 - 64bit Production
PL/SQL Release 11.1.0.6.0 - Production
"CORE 11.1.0.6.0 Production"
I altered existing table EVENT_SUB - added 3 columns. After that, I noticed all the procedures which had mention of this table name went in INVALID status, even if its simple SELECT, ALTER OR INSERT as shown below..
SELECT * FROM EVENT_SUB
OR 
INSERT INTO EVENT_SUB...
OR 
ALTER TABLE EVENT_SUB
WHERE....
So I had to recompile all the procedures associated with it. Is there any other ways to achieve this, like a line of code to add in the procedure itself, right after this DDL statements.
Sometimes i use this:
select object_name, object_type from all_objects where owner='TOYCOM' and status='INVALID'
Then, I would simply recompile the invalid objects.
For indexes, i do...
 
alter index <name> rebuild;
BTW, I did try to preview message, and then click on Create Topic, it gave me error..again.
"A system error has occurred.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Jan 12, 2012
        I have the procedure with out parameter is ref cursor.
l_sql VARCHAR2(32767);
BEGIN
l_sql := 'select query with appending procedure IN aparameters';
OPEN rc_rpt FOR l_sql;
Here procedure IN parameter is a string with comma separated value which is appended in the dynamic query IN clause.So some time the size exceeded more then 32767 and getting error.If i am using normal parametrized cursor this issue is not there,but i want to return only ref cursor for some java purpose.My oracle version is 10g.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Sep 11, 2012
        I have a procedure(used to delete the data from all tables) which taking two parameters as input. like EXCS_kiwldate(1,'keepitems')[/color][/size] but it taking only one parameter at a time if i want to delete all data using that procedure by calling it in a cursor
how to write a cursor by giving loop function to delete the data once.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Aug 9, 2010
        I have created a Pl/SQl block as the following
Declare
v_dname dept.dname%type;
v_loc dept.loc%type;
v_empno emp.empno%type;
v_job emp.job%type;
p_result SYS_ refcursor;
Begin
open p_result for select distinct d.dname, d.loc, e.empno, e.job from dept d, emp e where d.deptno=e.deptno;
fetch p_result into v_dname,v_loc,v_empno,v_job;
dbms_output.put_line(v_dname||' '||v_loc||' '||v_empno||' '||v_job);
end;
This is throwing me error saying 
" ORA-06550: line 7, column 15:
PLS-00103: Encountered the symbol "REFCURSOR" when expecting one of the following:"
	View 11 Replies
    View Related
  
    
	
    	
    	
        Jan 7, 2013
        I have a procedure where my end result will give like
INSERT INTO ABC(A,B,C,D,ID) SELECT 1,2,3,4,P_ID FROM BBC WHERE P_ID=300; 
this is a bulk insert where having 30 records.if one record fail then nothing will be commited.error willbe moved into my error log table.
I want the insert statement to be record by record and commit the successful one and move the error into error log table.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Sep 22, 2012
        I have one package, that included so maany ref. cursor package..Now , i want to execute  of one procedure in this package, how can i do it ..
CREATE OR REPLACE package Pkg_HR As
Type Typ_Cur Is Ref cursor;
procedure getHR_initiate(pvFinYr Varchar2, Cur_HR_Init OUT TYP_CUR);
procedure getFin_Yr(Cur_Fin_Yr Out TYP_CUR);
procedure getCutOFfStatus(pvAppsee1_Appsr2_Review3 Varchar2, pvFinYr Varchar2, Cur_HR_Init OUT TYP_CUR);
procedure SetEmp_For_FinYr(pvFinYr Varchar2, Cur_Emp OUT TYP_CUR);
End Pkg_HR ;
My Package Body is :
CREATE OR REPLACE package body Pkg_HR As
procedure getHR_initiate(pvFinYr Varchar2, Cur_HR_Init OUT TYP_CUR)
IS
Begin
Open Cur_HR_Init For
Select HR_FINYR HR_FinYr, To_Char(HR_PERIOD_FROM,'DD/MM/RRRR') HR_PERIOD_FROM
[code].....
	View 2 Replies
    View Related
  
    
	
    	
    	
        Nov 10, 2010
        This is regarding a problem we are facing during report(.xls) creation which is done using a procedure triggered by a job run. 
  
The report file(.xls) file is not getting created when the job(using dbms_scheduler) calls. 
  
The procedure uses utl_file to create an .xls file 
  
We have a folder on the path /oracle/tata_aig_life/websales/dnld . This folder( dnld ) has the all the priviliges drwxrwxrwx.
  
We have a job scheduler as the attachment which in turn triggers a procedure(check the code attachment for the scheduler and the procedure). 
  
In the procedure we first remove the file(.xls) created in the path and then recreate a new .xls file. 
  
The reason for first removing the file and recreating is that the existing file is not getting updated with a new file when the job is run. 
We capture the exceptions in a table. In the table the following exception is logged :ORA-29283: invalid file operation 
The job is triggered and the files are created on the path mentioned in the procedure on the UAT Environment.. 
  
Also the files are created when we manually run the same procedure in the path. 
   
The Oracle version is Oracle Database 10g Enterprise Edition Release 10.2.0.2.0 - 64bit Production 
The OS flavour is SunOS otlpsr5cora01 5.10 Generic_127111-11 sun4u sparc SUNW,Sun-Fire-V490 ------- 
	View 1 Replies
    View Related
  
    
	
    	
    	
        May 13, 2010
        I'm running a PL/SQL with a For Loop cursor, but when trying to execute it doesn't run. It is as if there is no data, but I ran the cursor separately in a SQL Plus session and it runs perfectly. I'm enclosing the file with the procedure.
	View 18 Replies
    View Related
  
    
	
    	
    	
        May 20, 2013
        I am running this procedure but it will not compile. I get the error "PLS-00356: 'REC.XX' must name a table to which the user has access"
All of the query results from the cursor are correct.
create or replace procedure SWDCADMIN.Hard_Delete_Client( cltId IN number)
IS
cursor c1 IS
  select
        t1.table_name xx,
        t1.owner || '.' || t1.TABLE_NAME uu,
      
[code]...
	View 15 Replies
    View Related
  
    
	
    	
    	
        Sep 12, 2011
        I have a DML Statement inside a procedure and i use a cursor variable to get the values checked as below . I have attached my procedure not completely but the declaration part and the DML statement part.
The issue is my procedure is not inserting the records at all. It selects the values and then inserts accoringly but its not selecting because of the cursor reference R_LOC.LOCATION_GID.
when i hard code the value in the DML statemnt for the R_LOC.LOCATION_GID, the rows are inserted as expected. So i guess the way the procedure executes the value is not correct.
Modifying my select part which uses cursor variable R_LOC.LOCATION_GID under Insert statement. 
select d.servprov_gid, d.depot_gid, replace(d.appointment_time,'':'') appmt_time, d.'||v_day_to_use||' DayUsed
from tesco_fresh_templates t, tesco_fresh_templates_d d, location_refnum r
where t.set_id= d.set_id
and d.depot_gid=r.location_gid
AND D.SERVPROV_GID=''R_LOC.LOCATION_GID''
and r.location_refnum_qual_gid=''TESCO.IVS SCHEDULING''
and (r.location_refnum_value=''YES'' or r.location_refnum_value=''Y'')
and t.default_set=''Y''
	View 21 Replies
    View Related
  
    
	
    	
    	
        Nov 19, 2013
        I am writing this procedure with a explicit cursors defined in it.  However when i compile the procedure i get this error: Error(39,1): PL/SQL: SQL Statement ignored Error(39,1):PLS-00394: wrong number of values in the INTO list of a FETCH statement .
create or replace PROCEDURE PRO_ICMISd_customer_no BB_PM.customer_no%type;d_pr_code_bbl BB_PM.pr_code_bbl%type;d_pr_code_pmm BB_PM.pr_code_pmm%type;d_subdept_desc PM.subdept_desc%type;d_class_desc PM.class_desc%type;d_cat_desc PM.cat_desc%type;d_subcat_desc PM.subcat_desc%type;d_brand_name PM.brand_name%type;d_product_desc PM.product_desc%type;d_unit_price_bbl PM.unit_price%type; e_customer_no BB_PM.customer_no%type;e_pr_code_bbl BB_PM.pr_code_bbl%type;e_pr_code_pmm BB_PM.pr_code_pmm%type;e_subdept_desc PM.subdept_desc%type;e_class_desc PM.class_desc%type;e_cat_desc PM.cat_desc%type;e_subcat_desc PM.subcat_desc%type;e_brand_name PM.brand_name%type;e_product_desc 
[code]....
	View 17 Replies
    View Related
  
    
	
    	
    	
        Jul 31, 2012
        I'm trying to fetch data from Ref Cursor OUT parameter filling by stored procedure. Using latest version of ODP.NET provider (11.2.0.3.0).
My stored procedure:
TYPE cursor_type IS REF CURSOR;
PROCEDURE test_proc (p_recordset out cursor_type) AS
BEGIN
OPEN p_recordset FOR
SELECT 1,2, CURSOR (SELECT 3,4 FROM dual)
FROM dual
END;
END test_proc;
If i'm removing "*CURSOR (SELECT 3,4 FROM dual)*" from the procedure, all works just fine. But when the nested cursor exists in procedure, i'm getting the following exception:
System.NullReferenceException occurred
Message=Object reference not set to an instance of an object.
Source=Oracle.DataAccess
StackTrace:
at Oracle.DataAccess.Client.OracleDataReader.GetOraDbTypeEx(Int32 i)
[code]........
My c# code:
using (OracleConnection conn = new OracleConnection(connString))
*{*
OracleCommand command = new OracleCommand();
command.Connection = conn;
command.CommandType = System.Data.CommandType.StoredProcedure;
command.CommandText = "test_proc";
[code].......
If i'm changing procedure signature from out parameter, to return value, code throws the same exception.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Oct 18, 2012
        The Oracle DB in question is 11.2.0.1, x64, Server 2008.I also have a SQL Server 2005 database that runs a third party product, "PaperVision", which we use to manage documents of various kinds. This SQL Server server is also Win 2008, x64.Now, on the server that runs SQL Server, I have a simple view which is defined as such : 
select DOCID,
DOCINDEX1,
DOCINDEX2,
DOCINDEX3,
DOCINDEX4,
DOCINDEX5,
DOCINDEX6,
DOCINDEX7,
DOCINDEX8,
[code]....
This view works great from the SQL Server side.  I also created a database link from Oracle to the SQL Server machine, and it also works great.It is defined as such : 
CREATE PUBLIC DATABASE LINK PVE_SQLSERVER
 CONNECT TO EVP_PVE_USER
 IDENTIFIED BY <PWD>
 USING 'PVE_SQLSERVER';
Where EVP_PVE_USER is a user created on the SQL Server machine with rights to select from this view.I know it works because I get results with a sql command like : 
select * from VW_PVE_DOCS_1_1@PVE_SQLSERVER;
I also created a view on the Oracle server that refines this information.  It is defined as such : 
CREATE OR REPLACE FORCE VIEW EVPDBA.VW_PVE_CONTRACTS_INALERT
(
   DOCID,
   EFFECTIVE_DATE,
   EXPIRATION_TYPE,
   ALERT_PERIOD_START,
   ALERT_PERIOD_END,
   ACRONYM,
  [code]....
This view also works fine, i.e., I can select * from it from the sql command line.Now, the problem comes in when I need to run a procedure that processes this view every night and/or week.I have stripped everything out of this procedure that is not relevant, and it is defined as such for this forum : 
CREATE OR REPLACE PROCEDURE EVPDBA.TESTME 
is
    tnum number := 0;
begin
    select count(*) into tnum from VW_PVE_CONTRACTS_INALERT;
end;
/
If I execute this procedure from the sql command line, all is well.When I run it from a scheduler job, I get 
ORA-01010: invalid OCI operation
ORA-02063: preceding line from PVE_SQLSERVER
ORA-06512: at "EVPDBA.TESTME", line 5
ORA-06512: at line 1
ORA-06512: at "SYS.DBMS_ISCHED", line 185
ORA-06512: at "SYS.DBMS_SCHEDULER", line 486
ORA-06512: at line 1
I am aware that DBMS_SCHEDULER performs a commit when scheduling a job, however, this is not scheduled from a trigger.I scoured the forums and have found a few things that seemed relevant, but not much.  One had to do with the version of the JDBC driver between two Oracle databases, but I wonder if the age difference between Oracle 11 and SQL Server 2005 (Express) might be an issue.  The fact that all command line select statements and running the procedure work fine implies to me that there is an additional issue raised due to the scheduler.
The other posts I found talked about performing a commit just before any select that ultimately pulls across a db link.  I did this, and still no luck.One other useful fact - the job appeared to run succesfully at 5am, yet trying again at 8am threw the error, so it may be sporadic.  (Although during regular daytime hours it is a very repeatable error).
I am looking into reformatting things to use the older DBMS_JOB, however, I really like the log history of job details and other functionality available with SCHEDULER.
	View 5 Replies
    View Related
  
    
	
    	
    	
        Mar 30, 2012
        How to overcome this error
SQL> create or replace trigger trig_insert
2  before insert  on insuredpersons for each row
3  begin
4    insert into sms_icare(insuredid)values(:new.id);
5    end;
when i am trying to insert it is throwing error is
ORA-04098:trigger "marbke.trig.sms' is invalid and failed re-validation
	View 2 Replies
    View Related
  
    
	
    	
    	
        Jul 24, 2012
        select to_char(123.5,'fm$99999.00') from dual
when I execute this I get an output of $123.50...I want to use other speacial characters like @,* instead of $...But I am getting invalid identifier error if I use any special character other than $.
	View 5 Replies
    View Related
  
    
	
    	
    	
        May 9, 2011
        I'm getting the following error in my DB, what would be the reason.
select * from Table_Name where rownum<10
                          *
ERROR at line 1: ORA-01722: invalid number
and I'm getting this error for every query.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Apr 12, 2012
        How do i execute and display results of a procedure declared with ref cursor OUT parameter.
I am using SQL Developer and Oracle 10.2.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Apr 5, 2011
        To keep things simple: lets say that this is my procedure:
create or replace procedure testSp(x out sys_refcursor )
is
begin
open x for
select 1 from dual;
end;
how would i be able to execute this from with in sqlTools to see the result ??? i have tried everything...
my goal is in the end to execute this from Magic 8 (to those who herd of it). p.s this needs to work in oracle 8
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jul 30, 2010
        The following runs no problem
SELECT
ACCO.SEQUENCE,
ACCO.DESCRIPTION,
MAX (ACCO.AUDIT_DTE)
FROM
PAS.AUDIT_CLINICAL_CARE_OPTIONS ACCO
WHERE
ACCO.AUDIT_DTE < :AuditDate AND
[code]....
However, when I try to add extra conditions to the status' in the sub select i get the error. This is one way I tried:
SELECT
ACCO.SEQUENCE,
ACCO.DESCRIPTION,
MAX (ACCO.AUDIT_DTE)
FROM
PAS.AUDIT_CLINICAL_CARE_OPTIONS ACCO
WHERE
[code]....
I've tried repeating the sub select for each of the extra status parts but everytime i hit the same problem.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Mar 9, 2007
        INSERT INTO t_category m(       
m.service_id,               
m.customer_id)       
SELECT 
u.service_id,         
(SELECT p.add_data
FROM t_add p
WHERE 
p.service_id=u.service_id  AND p.add_type='CUSTOMER_ID')       
FROM   t_iservice u
I got this error: ORA-01722: invalid number.  The problem is m.customer_id has data type NUMBER, p.add_data is VARCHAR. 
	View 1 Replies
    View Related
  
    
	
    	
    	
        Mar 4, 2012
        way give error in package below
SQL> CREATE OR REPLACE PACKAGE DATA_BKG AS
  2         
  3  TYPE OBJ_DEPT IS RECORD
  4  (
  5  DEPT_ID   NUMBER(10),
  
[code]...
	View 7 Replies
    View Related
  
    
	
    	
    	
        Nov 17, 2012
        I am receiving the SQL Error when trying to do a simple insert statement..
Below is the supposed errant SQL..WHERE?
SQL
insert into (CUSTOM_TBL)
Select
'123456' --CHARTFIELD2
,'PR' --EXAMPLE COMMENT
,'123456_01' --EXAMPLE COMMENT - 
SEE ERROR STATEMENT BELOW:
Error at Command Line:5 Column:10
Error report:
SQL Error: ORA-00911: invalid character
00911. 00000 -  "invalid character"
[code]....
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jul 26, 2011
        I have a problem when executing the statement below querying a specific ID# in view
select * from VW_MML_LTR_MSTR  where LTR_ID = 26 order by CLNT_CDE ,LTR_GRP, ltr_purp_id, LTR_CDE 
I checked the data type acquired by the view and the table involved and confirmed that it was of number type.Weird thing for me is that I changed the where statement as
where LTR_ID LIKE 26
where LTR_ID != 25
 Is this on the database settings? What should be done here?
	View 9 Replies
    View Related
  
    
	
    	
    	
        Jan 13, 2011
        The following query gives me "Invalid Identifier error: ORA-00904. 
SELECT     TMADMIN.pkg_twatch_invdb.Max_Trk_Date(tmadmin.sites.study_id,tmadmin.sites.site_id, 1000280)) "Qualified Date"   
FROM 
tmadmin.sites
"tmadmin' is the Schema Name 
"pkg_twatch_invdb" is the package name
"max_trk_date" is a function inside the package (returns date)
I am using the same format for other function, it doesn't give any errors.
	View 4 Replies
    View Related