Solved

ora-01795: maximum number of expression in a list is 1000

Posted on 2015-01-13
5
200 Views
Last Modified: 2015-01-24
hi i have the following query

select * from cal_obj
where obj_name in ('obj1','obj3' etc) I have more tha 1000+ obj how can I work around this after I get this values I also what to delete tham am in 11gr2
0
Comment
Question by:chalie001
  • 2
  • 2
5 Comments
 
LVL 76

Expert Comment

by:slightwv (䄆 Netminder)
Comment Utility
Break them up into several lists:

where
(
obj_name in ('obj1','obj3' etc)
or
obj_name in ('obj1001','obj1003' etc)
)
...

or

Place all the objects in a temp table then do:
where obj_name in (select tmp_object_name from tmp_object_table) ...


There are a couple of other ways but those are probably the most straight forward.

>> I also what to delete tham am in 11gr2

Change the outer most select to a delete?
0
 
LVL 73

Assisted Solution

by:sdstuber
sdstuber earned 500 total points
Comment Utility
put them into a collection object
collections have no limit on members

select * from cal_obj
where obj_name in (select * from table(your_collection));

simple example...

create or replace type vcarray as table of varchar2(20);

select * from cal_obj
where obj_name in (select * from table(vcarray('obj1','obj3')));
0
 

Author Comment

by:chalie001
Comment Utility
how can i do this in better way

CREATE OR REPLACE TYPE         "VARCHAR2TABLE"                                          AS TABLE OF VARCHAR2(50)

CREATE OR REPLACE FUNCTION SMS01.F_VARCHAR2_TABLE (ccode_list       IN  VARCHAR2,
     p_delimiter  IN  VARCHAR2 DEFAULT ',')
RETURN varchar2Table
PIPELINED
   IS
      v_string  LONG := ccode_list || p_delimiter;
      v_pos     PLS_INTEGER;
      v_data      varchar2Table :=  varchar2Table();
    BEGIN
     LOOP
       v_pos := INSTR(v_string, p_delimiter);
       EXIT WHEN (NVL(v_pos, 0) = 0);
       v_data.extend;
       v_data(v_data.COUNT) := trim(SUBSTR(v_string, 1, v_pos - 1));
       v_string := SUBSTR(v_string, v_pos + 1);
     END LOOP;
     RETURN ;
   END F_varchar2_Table;
/


CREATE OR REPLACE PROCEDURE SMS01.SMS_SUSPEND_BYCCODE (p_ccode VARCHAR)
IS
--procedure to suspend by ccode and exclude  from a pay run
CURSOR get_agree IS
SELECT a.id aid, a.ssch_id, a.contract_no, b.id ayea_id, b.asta_id, b.status_date, b.comments
FROM SMS_AGREEMENTS a,
SMS_AGREEMENT_YEARS b,
SMS_PARTIES par
WHERE a.id = b.agr_id
AND b.fyea_year = 2011
AND par.id = a.par_id
AND  par.c_code IN (SELECT *  FROM TABLE(cast(F_Varchar2_Table_Pipe(p_ccode)AS VARCHAR2TABLE)));

cnt INTEGER;

BEGIN

cnt := 0;

SELECT COUNT(*) INTO cnt FROM SMS_AGREEMENTS a,
SMS_AGREEMENT_YEARS b,
SMS_PARTIES par
WHERE a.id = b.agr_id
AND b.fyea_year = 2011
AND par.id = a.par_id
AND par.C_CODE IN (SELECT *  FROM TABLE(cast(F_Varchar2_Table_Pipe(p_ccode)AS VARCHAR2TABLE)));

cnt := 0 ;


    FOR agree_rec IN get_agree LOOP
	cnt := cnt + 1;

        UPDATE SMS_AGREEMENT_YEARS
        SET asta_id = 2444,
        --comments = 'UNSUSPEND ON REQUEST BY MICHAEL'
		 comments = 'SUSPEND ON REQUEST BY MICHAEL'
        WHERE id = agree_rec.ayea_id;
    END LOOP;
	COMMIT;

	dbms_output.put_line('data records updated ' || cnt);


END Sms_Suspend_Byccode;
/

Open in new window

0
 
LVL 73

Accepted Solution

by:
sdstuber earned 500 total points
Comment Utility
your function doesn't ever return the collection.

try one of these, one pipelined, one not

CREATE OR REPLACE FUNCTION f_varchar2_table(
    ccode_list    IN VARCHAR2,
    p_delimiter   IN VARCHAR2 DEFAULT ','
)
    RETURN varchar2table
    PIPELINED
IS
    v_string LONG := ccode_list || p_delimiter;
    v_pos    PLS_INTEGER;
BEGIN
    LOOP
        v_pos := INSTR(v_string, p_delimiter);
        EXIT WHEN (NVL(v_pos, 0) = 0);

        PIPE ROW (TRIM(SUBSTR(v_string, 1, v_pos - 1)));
        v_string := SUBSTR(v_string, v_pos + 1);
    END LOOP;

    RETURN;
END f_varchar2_table;
/



CREATE OR REPLACE FUNCTION f_varchar2_table(
    ccode_list    IN VARCHAR2,
    p_delimiter   IN VARCHAR2 DEFAULT ','
)
    RETURN varchar2table
IS
    v_string LONG := ccode_list || p_delimiter;
    v_pos    PLS_INTEGER;
    v_data   varchar2table := varchar2table();
BEGIN
    LOOP
        v_pos := INSTR(v_string, p_delimiter);
        EXIT WHEN (NVL(v_pos, 0) = 0);
        v_data.EXTEND;
        v_data(v_data.COUNT) := TRIM(SUBSTR(v_string, 1, v_pos - 1));
        v_string := SUBSTR(v_string, v_pos + 1);
    END LOOP;

    RETURN v_data;
END f_varchar2_table;
/
0
 

Author Closing Comment

by:chalie001
Comment Utility
correct
0

Featured Post

PRTG Network Monitor: Intuitive Network Monitoring

Network Monitoring is essential to ensure that computer systems and network devices are running. Use PRTG to monitor LANs, servers, websites, applications and devices, bandwidth, virtual environments, remote systems, IoT, and many more. PRTG is easy to set up & use.

Join & Write a Comment

Truncate is a DDL Command where as Delete is a DML Command. Both will delete data from table, but what is the difference between these below statements truncate table <table_name> ?? delete from <table_name> ?? The first command cannot be …
Configuring and using Oracle Database Gateway for ODBC Introduction First, a brief summary of what a Database Gateway is.  A Gateway is a set of driver agents and configurations that allow an Oracle database to communicate with other platforms…
This video shows setup options and the basic steps and syntax for duplicating (cloning) a database from one instance to another. Examples are given for duplicating to the same machine and to different machines
This video shows how to copy an entire tablespace from one database to another database using Transportable Tablespace functionality.

743 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

8 Experts available now in Live!

Get 1:1 Help Now