SQL & PL/SQL :: Function Return Multiple Rows
			Jun 23, 2006
				can i have a pl/sql function that can return multiple rows
may be the syntax will be like
create or replace function multiple() returns ...
begin
   select candidateid from tbl_candidateinfo;
   
   ..code to return the result of above statement to calling program.. 
end;
and functions will be called as
select candidateid from .. where candidateid in( select multiple());
	
	View 13 Replies
  
    
		
ADVERTISEMENT
    	
    	
        Jun 6, 2013
        I need a function that should return output of this query
SELECT b.branding_code, c.name_desc 
FROM 
development.brandings b, godot.company c
WHERE b.company_id = c.company_id;
This above function return 30 rows and I am not giving any input
Function using cursor,pipeline
	View 5 Replies
    View Related
  
    
	
    	
    	
        Apr 30, 2010
        I need to return results for the following query only when there are two or more rows found by the following:
SELECT DISTINCT D.PUBLICATION, 
D.ADI, 
D.DISTRICT, 
D.ACCOUNT, 
D.ROUTE, 
[code]......                
Expected results would be:
1 145 CRF TUANR000 VM BILLETING 16-APR-10 5 5 23-APR-10   48623
1 145 CRF TUANR000 VM BILLETING 16-APR-10 5 4 23-APR-10   48629
	View 19 Replies
    View Related
  
    
	
    	
    	
        Aug 28, 2010
        I want multiple values from a function. I want to use this function in a SQL query. Here i'm giving my try.
SQL> CREATE TABLE TEMP
  2  (
  3    ID        NUMBER(1),
  4    SAMPTYPE  VARCHAR2(20 BYTE),
  5    SALARY    NUMBER(10)
  6  )
  7  /
Table created. 
SQL> INSERT INTO TEMP VALUES(1,'ABC',10000);
1 row created.
SQL> INSERT INTO TEMP VALUES(2,'PQR',20000);
1 row created.
SQL> INSERT INTO TEMP VALUES(3,'JPD',5000);
1 row created.
SQL> COMMIT;
Commit complete.
[code]...
Here i get result as ABC*10000, but i want two separate values as ABC,10000. how can i do this via function.
	View 6 Replies
    View Related
  
    
	
    	
    	
        Jun 7, 2013
        If I return multiple rows says ex:100 rows then what will be data type for that return values.
	View 1 Replies
    View Related
  
    
	
    	
    	
        May 26, 2010
        How to return multiple rows from the stored procedure in ORACLE..
	View 2 Replies
    View Related
  
    
	
    	
    	
        Mar 27, 2013
        EMP table
create table emp1 (empno number,deptname varchar2(30),deptno number,sal number);
insert into emp1 values (1,'Bank',10,1000);
insert into emp1 values (1,'Finance',20,400);
insert into emp1 values (2,'Finance',20,4000);
insert into emp1 values (3,'Account',30,3000);
commit;
select * from emp1;
actual output :
empno  deptname  deptno sal
1       Bank      10    1000
1       Finane    20    400
2       Finane    20    4000
3       Account   30    3000
Expected output :
empno  deptname  deptno sal
1       Bank      10    1000
2       Finane    20    4000
3       Account   30    3000
I am looking a output like above one. if any empno belongs to deptname Bank then give priority to that values else go to other dept like Finance but empno 1 should return only one row.i.e Bank dept only.
I have to return only one row based on dept values for one empno. how to do in sql or plsql?
	View 11 Replies
    View Related
  
    
	
    	
    	
        Sep 13, 2012
        I've used PIPELINED FUNCTION and I've no issues in using this. Just wanted to know is there a way so that I don't need to pipe each row separately and I can pipe a set of rows at once.
Like we use BULK COLLECT INTO to fetch multiple rows at once instead of fetching one row using SELECT INTO.
Below is the test case:
CREATE TABLE TMP_EMP
(
EMP_ID          NUMBER(10,0), 
EMP_NAME        VARCHAR2(100), 
DEPT_ID         NUMBER(10,0), 
SALARY          NUMBER(14,0), 
[code]....
	View 13 Replies
    View Related
  
    
	
    	
    	
        Apr 22, 2010
        Client managerCont. Start DateCont. End Date
abcman11-Jan-0830-Jun-08
abcman21-Jul-0831-Dec-08
abcman11-Jan-0930-Jun-09
abcman11-Jul-0931-Dec-09
abcman21-Jan-1031-Mar-10
abcman21-Apr-1031-Aug-10
I need to code a SQL statement (Not PL/SQL) to display following records:
Client managerCont. Start DateCont. End Date
abcman11-Jan-0830-Jun-08
abcman21-Jul-0831-Dec-08
abcman11-Jan-0931-Dec-09
abcman21-Jan-1031-Aug-10
	View 4 Replies
    View Related
  
    
	
    	
    	
        Sep 30, 2013
        I am fetching records from many voluminous tables having multiple joins based on filter criteria filled from frond end application. As per the selected criteria, I want to have a pre-check if query would return more than 1000 rows then I have to show user a message saying that he should refine the search. Is there any performant way to query db and dynamically find record count and stops executions if it is going return more than the specified no of rows.
	View 5 Replies
    View Related
  
    
	
    	
    	
        Dec 5, 2006
        The function definition in PL/SQL has IN OUT parameter as well as return statement. Using both we can return the values. Basic definition of a function is function can return only one value at a time.
The question is, Can we return a number thru return statement and a char value thru INOUT parameter. Is it possible to return two different values using these?
	View 1 Replies
    View Related
  
    
	
    	
    	
        Nov 14, 2011
        Following is the scenario:
CREATE OR REPLACE TYPE OBJ IS OBJECT
(
TEST_ID   NUMBER(9),
TEST_DESC VARCHAR(30)
)
/
[Code]..
I WANT USED VALUE TEST_ID AND TEST_DESC THE EXISTING IN FUNCTION FN_MY_DATA WITH A VARIABLES :
DECLARE 
X NUMBER(9);
Y VARCHAR(30);
BEGIN
X := -- VALUE TEST_ID EXISTING IN FN_MY_DATA;
Y := -- VALUE TEST_DESC EXISTING IN FN_MY_DATA;
END;
	View 3 Replies
    View Related
  
    
	
    	
    	
        Aug 2, 2010
         whether a function can return two values?
	View 4 Replies
    View Related
  
    
	
    	
    	
        Aug 30, 2012
        I have a database in 10g in entreprise edition but i don't understand why the dba_feature_usage_statistics return no rows ? On some database when i look at dba_ feature_usage_statistics Protection Mode - Maximum Performance is used and active why?
	View 4 Replies
    View Related
  
    
	
    	
    	
        Oct 17, 2012
        How to merge multiple rows into single row (but multiple columns) efficiently.
For example
IDVal IDDesc IdNum Id_Information_Type Attribute_1 Attribute_2 Attribute_3 Attribute_4 Attribute_5
23 asdc 1 Location USA NM ABQ Four Seasons 87106
23 asdc 1 Stats 2300 91.7 8.2 85432 
23 asdc 1 Audit 1996 June 17 1200
65 affc 2 Location USA TX AUS Hilton 92305
65 affc 2 Stats 5510 42.7 46 9999
65 affc 2 Audit 1996 July 172 1100
where different attributes mean different thing for each Information_type. For example for Information_Type=Location
Attribute_1 means Country
Attribute_2 means State and so on.
For example for Information_Type=Stats
Attribute_1 means Population
Attribute_2 means American Ethnicity percentage and so on.
I want to create a view that shows like below:
IDVal IDDesc IDNum Country State City Hotel ZipCode Population American% Other% Area Audit Year AuditMonth Audit Type AuditTime
23 asdc 1 USA NM ABQ FourSeasons 87106 2300 91.7 46 85432 1996 June 17 1200
65 affc 2 USA TX AUS Hilton 92305 5510 42.7 46 9999 1996 July 172 1100
	View 1 Replies
    View Related
  
    
	
    	
    	
        Sep 6, 2012
        I have a sql query as below :
select order_number,
(select decode(hcp.contact_point_purpose,'ABC',hcp.email_address,'CDE',hcp.email_address,null)
from hz_contact_points,
hz_parties hz
WHERE hz.party_id=hcp.owner_table_id) Email 
FROM oe_order_headers_all h
WHERE h.order_number='102'
....................
..............
Actually the problem i am facing is the inner select query is returning multiple row , so my main query is erroring out, i need to capture the multiple row.
In the above example the inner decode statement returning two mail address, I need to capture that, but while executing the whole query it is erroring out as saying single query returns multiple values. capture multiple values
	View 3 Replies
    View Related
  
    
	
    	
    	
        Mar 13, 2012
        I have a table second_table which has a username and code field. A username (not the primary key) may be entered multiple times with different codes, or a single code 'ALL', in which case, the codes have to be fetched from 'third_table'. I am unable to form a 'case' clause to handle the fact that a list has to returned when the 'code' field from the second_table returns 'ALL'. 
e.g.
Second_table
username code
A        ALL
B        23
B        56
B        33
Third_Table
code
67
78
So, when the user asks the codes for user A, he should get 67 and 78 and when he asks for the user B, he should get 23,56 and 33
	View 13 Replies
    View Related
  
    
	
    	
    	
        Sep 26, 2010
        I was just wondering that do we have any function available in oracle which returns the last Friday of the month.
In our company we close our monthly books on last Friday of the month and there are few activities that we have to do on the following Monday as a part of month-end activity. Now the following Monday can fall on the same month or at times it falls on the following month.
I have to schedule a report to be sent to a user on the following Monday after the month-end. I need to schedule it using the cron job.
We are using Oracle 9i on Linux platform.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Apr 29, 2010
        i want to create a function that build a return xml (XmlType):
create or replace
function plainLanguageSummary(nip varchar2,id number,code_language varchar2) return XmlType
as
[Code].....
but in the compilation i got the following error :
Error(10,62): PLS-00103: Encountered the symbol "SELECT" when expecting one of the following:     ( - + case mod new not null others <identificateur>    <identificateur entre guillemets> <variable bind> avg count    current exists max min prior sql stddev sum variance execute    forall merge time timestamp interval date    <un littéral de chaîne avec spécification de jeu de caractères>    <un nombre> <une chaîne SQL entre apostrophes> pipe    <constante de chaîne éventuellement entre guillemets avec indication du jeu de
he seems to not like the first "select" he encounter!.
	View 9 Replies
    View Related
  
    
	
    	
    	
        Jun 22, 2010
        i'm trying to make a sp/function for inserting a record and return the new index.The previous code used regular inserts and needed an additional round-trip to get the id before inserting,, since this is part of a import routine performance is an issue.
CREATE OR REPLACE PROCEDURE SaveAisHeader (
    P_Id Out Number,
    P_ImportedOn IN Date,
    P_Aisimporttypeid In Number,
    P_Description In Varchar2,
    P_Importedby In Varchar2
  [code].....
	View 12 Replies
    View Related
  
    
	
    	
    	
        Jul 6, 2012
        This error is returned when executing a Function with the RETURN X%ROWTYPE is used.Here is the code.
CREATE OR REPLACE function FE_GET_addr (
p_PIDM IN addr.addr_PIDM%TYPE,
p_atyp1 IN VARCHAR2,
p_atyp2 IN VARCHAR2,
p_atyp3 IN VARCHAR2,
p_atyp4 IN VARCHAR2
[code]....
	View 5 Replies
    View Related
  
    
	
    	
    	
        Feb 1, 2012
        how to decide whether to use a procedure or  function if i have to return only 1 datatype.
	View 5 Replies
    View Related
  
    
	
    	
    	
        Nov 23, 2011
        I have a history table which has a new record written to it for every time static data is updated. What I want to do is return any record that has been changed on a daily basis returning both the new record and the previous record so you can see the 2 records one below the other and compare.I have written the below but it returns all records per account:
SELECT H.Timestamp,H.AccountNo FROM History H
where exists (select H2.AccountNo,count(*) from History H2
where H2.AccountNo = H.AccountNo
group by H2.AccountNo having count(*) > 1 )
Where H.Timestamp > '20111101'
order by H.AccountNo,H.Timestamp
	View 18 Replies
    View Related
  
    
	
    	
    	
        Jan 10, 2012
        I have not found a solution for this, but it could be that I don't know what to search for.
I need to edit the following statement:
SELECT a.id||a.name||a.amount*2 as transaction
FROM a
WHERE a.amount IN (500, 1000)
To return:
TRANSACTION     
------------------------------------
123SMITH1000
123SMITHADJUSTED AMOUNT PER X
456JONES2000
456JONESADJUSTED AMOUNT PER X
The returned rows need to be in this format to be executed in another database.
Can this be done?
	View 8 Replies
    View Related
  
    
	
    	
    	
        Feb 16, 2011
        I am new to SQL and I am just wondering if there is a solution to a problem I am having.I am using the piece of code below.Essentially what I am doing is selecting a field from a table and ordering that field in descending order. Using the Row_Number feature I then specify which Row I want to return.
Every day the row I will want is the Count of field1 for that day divided by 100 minus 1. This returns a single value of field1 and a single value of R.
I perform this operation every day. The only fields I change every day are the dates and the value of R. I use a seperate piece of SQL code to calculate R each day.
My problem is I have to often populate historical tables with this data. I can only run the code once for each day and for each value of R. Is there anyway I can alter this code such that it can return multiple values of field1 over several dates?The only way I can think of is to repeat the code multiple times using UNION but I am hoping there is a more efficient way.
SELECT * 
  FROM (SELECT Field1,               
               ROW_NUMBER() OVER (ORDER BY field1 desc ) R
               FROM table 
               WHERE  date >= TO_DATE ('20110215', 'YYYYMMDD')
               AND date <  TO_DATE ('20110216', 'YYYYMMDD')                 
  ) 
 WHERE R = 1227 
--Note: 1227 = (count(field1)/100)-1
	View 5 Replies
    View Related
  
    
	
    	
    	
        Feb 6, 2006
        I have created a Package Body and Package Spec for a function to select a username and a password from a table and return the username. 
The code i have created is this:- 
CREATE OR REPLACE PACKAGE BODY USER_LOGIN
AS
FUNCTION user_select (USERNAME_IN   VARCHAR2,
PASSWORD_IN   VARCHAR2)
RETURN VARCHAR2 IS
USERNAME_OUT  VARCHAR2(12);
BEGIN
[code]........     
The package body and spec compiles successfully but i am having trouble when i execute this function. I am trying to do this :-
VARIABLE RETVAL VARCHAR2(12)
EXEC User_login.user_select('HELLO','HELLO',:RETVAL ); 
but i am getting the following error
ERROR at line 1:
ORA-06550: line 1, column 7:
PLS-00306: wrong number or types of arguments in call to 'USER_SELECT'
ORA-06550: line 1, column 7:
PL/SQL: Statement ignored
	View 5 Replies
    View Related
  
    
	
    	
    	
        Dec 12, 2012
        Can a Oracle Function return Images? I have been getting and able to read lot of solutions but still unconfirmed. As in certain forums it has been mentioned that the difference between procedure and function is that. With procedures you are able to return images but not with function.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Feb 17, 2011
        I have strange problem when i try to return a ref cursor holding data from a select on a oracle global temporary table. If i iterate through the cursor , i can see the values but the function as such returns nothing through the ref cursor. I tried the temporary table as both delete on commit and preserve on commit
create or replace
PACKAGE BODY BILL AS
FUNCTION FILTERI RETURN BILL.refcursor IS
testcursor BILL.refcursor;
ttstatus INT;
iSuccess INT;
returns INT;
TruncatedSQL1 VARCHAR2(32767);
BEGIN
[code].........
	View 12 Replies
    View Related
  
    
	
    	
    	
        Jul 25, 2012
        I am trying to create a function which would return a nested table with 3 columns of a table as a type.
my query is like 
select col1,col2,col3 from table_1;
	View 4 Replies
    View Related
  
    
	
    	
    	
        Apr 1, 2012
        I need to get the super set(parent) record from a relational table. Following is the structure of the table,
create table relation (data_field1 number(20),data_field2 number(20),data_field3 number(20),
    primary key (data_field1,data_field2,data_field3) );
    insert into relation (data_field1, data_field2, data_field3) values (-10,123,334);
    insert into relation (data_field1, data_field2, data_field3) values (200,123,334);
    insert into relation (data_field1, data_field2, data_field3) values (300,123,334);
    insert into relation (data_field1, data_field2, data_field3) values (400,123,334);
[code].....
Here '-10' will be considered as parent(super set) for all other values. If i have records like below,
    -10   200  300
    100   200  300
    123   200  300
    521  201  300
Output should only contain two rows. A super set row and other distinct row(second column value is not equivalent to super set).
	View 14 Replies
    View Related