SQL & PL/SQL :: Month Wise Days For Between Given Dates?
			Apr 28, 2010
				I have a table with starting date and ending date.
I want to fetch monthwise days for given two dates
IE starting 25/12/2009 ending 25/03/2010
Result should like below.
Dec-09 7
Jan-10 31
Feb-10 28
Mar-10 25
I have tried this but it is not giving me the result which want..
select to_char(thedate,'mon-yy') mnth,count(to_char(thedate,'mon-yy')) days from
(SELECT TRUNC(to_date('25/12/2009','dd/mm/yyyy'),'Y')+ROWNUM-1 THEDATE
FROM   ( SELECT 1 just_a_column
FROM dual
CONNECT BY LEVEL <= 366
[code].....
	
	View 3 Replies
  
    
	ADVERTISEMENT
    	
    	
        Jun 4, 2013
        I have a requirement to list the data month wise dynamically where month data is also in the same table, hopefully the below posts should bring more clarity to my requirements.
1. Table creation:
Create table T1 (account_no varchar2(15), area_code varchar2(2), bill_month date, consumption number);
2. List table content:
select * from T1;
account_no  area_code  bill_month consumption
Q00001Q31-Jan-12125
Q00002Q31-Jan-1265
Q00003Q28-Feb-12219
Q00004Q28-Feb-12805
Q00005Q28-Feb-1254
Q00001Q31-Mar-12234
Q00002Q31-Mar-12454
Q00003Q31-Mar-12232
Q00004Q30-Apr-1221
Q00005Q30-Apr-12218
Q00001Q30-Apr-1254
Q00002Q31-May-1219
Q00003Q31-May-1287
Q00004Q30-Jun-12187
Q00005Q30-Jun-1278
so on......so on......so on......so on......
3. Expected output:
account_no area_code Jan-12 Feb-12 Mar-12 Apr-12 May-12Jun-12Jul-12Aug-12Sep-12Oct-12Nov-12Dec-12
Q00001    Q     125     548   2345487423154821518738721512
Q00002    Q     65     127   45487819357831585683152878
Q00003    Q     545     219   2328738735188745897313
Q00004    Q     78     805   1221218187885718387389787138
Q00005    Q     541     54   2621878778386538698182
With the conventional query I hope this is impossible, 
	View 2 Replies
    View Related
  
    
	
    	
    	
        Jan 26, 2011
        I want to find the dates which have a date plus with in 2 days after this date. I mean group by 3 days each even the date i missing between two days. Actualy I want to find the start date where the employ was missing on job.
Basic concept is employes have allowed to use 10 personal leaves of a year. Each leave can be use for maximum 3 days. 
If employ did not come on the job for one day or two days or three days, it shoul be count as ONE personal leave. And If employ is missing at job for four or five days, it should be count as 2 personal leaves.
seq              date
------------------------------
101.01.10
205.01.10
306.01.10
410.01.10
512.01.10
613.01.10
714.01.10
815.01.10
916.01.10
1018.01.10
1119.01.10
1220.01.10
1321.01.10
1423.01.10
1526.01.10
1627.01.10
1729.01.10
1831.01.10
 
The result should be (Don't use Pl/Sql)
seq              date
------------------------------
101.01.10
205.01.10
310.01.10
413.01.10
516.01.10
619.01.10
723.01.10
826.01.10
929.01.10
After finding these days I want to select the starting date of 5th personal leave. (which is 16.01.10).  
I am not a expert of using SQL, but I think it could be possible with using partitioning a table on the givin reslult and further partition the reslut on rownum() as rn and the using case statement where rn = 5.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Nov 2, 2010
        i want create a report like this
location   sysdate   refdate  No_of_days  SL1(0-90) SL2(91-180)  SL3(>180)
So when no. of days between (0-90) data put in SL1 
And  when no. of days between (91-180) data put in sl2
I want to achieve this only in single query.
	View 11 Replies
    View Related
  
    
	
    	
    	
        Jul 1, 2011
        I want to get the current month day wise count. I dont want Procedure. I need SQL Query only.For example:
 July 2011.
  Sunday -   5
  Monday -   4
  Tuesday -  4 
  Wednesday- 4
  Thursday - 4
  Friday -   5
  Saturday-  5
	View 3 Replies
    View Related
  
    
	
    	
    	
        Sep 11, 2012
        I have data something like this.
Employee_id    date_loggedin
123                  09/10/2012
134                  09/03/2012
111                  09/02/2012
123                  08/27/2012
134                  08/01/2012
123                  07/06/2012
111                  05/11/2012
123                  07/04/2012
123                  07/03/2012
123                  03/15/2012
123                  01/11/2012
The desired output for input of employee_id=123 and dates between 01/01/2012 and 09/30/2012
Month    login_count
JAN_2012     1
FEB_2012     0
MAR_2012     1
APR_2012     0
MAY_2012     0
JUN_2012     0
JUL_2012     3
AUG_2012     1
SEP_2012     1
	View 2 Replies
    View Related
  
    
	
    	
    	
        May 4, 2013
        I have a requirement as follows :-
The user will submit the start date and end date. Based on the date parameters, the customized procedure should do some calculations month-wise.
For eg : start date - 01-Dec-2012 to end date - 31-Mar-2013
I want the break up as 
Start date End date
01-dec-2012 31-dec-2012
01-jan-2013 31-jan-2013
01-feb-2013 28-feb-2013
01-mar-2013 31-mar-2013
How can i achieve this month-wise break ?
	View 6 Replies
    View Related
  
    
	
    	
    	
        Feb 24, 2013
        how to find out growth of database month wise?
according to me, v$datafile can be use to know growth in database in terms of datafiles added in past months as per creation_time. but hows about those existing datafiles whose size has been re size more .
Whats your inputs on this ??
	View 21 Replies
    View Related
  
    
	
    	
    	
        Mar 14, 2012
        I have not defined the table ( I only have privileges to query data).
I am unable to copy and paste my real code here, and the actual results from the run, as my company will fire me if I do so... so here is how things approximately look like (tried to keep it as real as possible).
Let's say that the table CYCLE has client numbers (clientid), cycle number (cycleno), date of visit (visdt).
I am trying to create a query to calculate how many days there are between each two consecutive visits/cycles for a single client(let's say 1200004)
clientid / cycleno / visdt 
---------------------------
1200004 / 1      / 10OCT2011
1200004 / 2      / 31OCT2011
1200004 / 3      / 21NOV2011
1200004 / 4      / 05DEC2011
1200004 / 5      / 03JAN2012
...
1000005 / 1      / 04NOV2011
1000005 / 2      / 03DEC2011
1200004 / 1      / 10JAN2012
1200004 / 2      / 15FEB2012
.
.
.
The code below is the only one that kind of seemed to work, but it is definitely not giving me the right results.
SELECT cycleno1, visdt1, cycleno2, visdt2, to_date(visdt1) - to_date(visdt2) days
FROM (SELECT clientid, cycleno cycleno1, visdt visdt1, 
LEAD (visdt, 1) OVER (ORDER BY cycleno) visdt2
FROM CYCLE) a
[Code]....
I am getting a mess of a result of the kind:
cycleno1 / visdt1 / cycleno2 / visdt2 / days 
--------------------------------------------
1      / 10OCT2011 / 1/ 18OCT2011 / -8
1      / 10OCT2011 / 2/ 18OCT2011 / -8
1      / 10OCT2011 / 3/ 18OCT2011 / -8
1      / 10OCT2011 / 4/ 18OCT2011 / -8
1      / 10OCT2011 / 5/ 18OCT2011 / -8
I need my result to look like:
cycleno1 / visdt1 / cycleno2 / visdt2 / days 
--------------------------------------------
1      / 10OCT2011 / 2/ 31OCT2011 / 21
2      / 31OCT2011 / 3/ 21NOV2011 / 22
3      / 21NOV2011 / 4/ 05DEC2011 / 15
4      / 05DEC2011 / 5/ 03JAN2012 / 30
5      / 03JAN2012 / /           / 
.
.
.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Sep 23, 2013
        how to write pl/sql to create date o/p like .
since we wnat to design pl/sql report wich will generate monthwise sale from 01jan2009 to 01-sep-2013.
we have created funtion wich will accept argument as employee no, from date and to date.
from_date     to_date
01-JAN-2009  01-FEB-2009
01-FEB-2009  01-MAR-2009
01-MAR-2009  01-APR-2009
01-APR-2009  01-MAY-2009
01-may-2009  01-JUN-2009
01-JUN-2009  01-JUL-2009
	View 4 Replies
    View Related
  
    
	
    	
    	
        Dec 29, 2012
        i need to find the number of days employee was absent for the month, we are maintaining a table of attendance , where the daily data of hours is captured, what i need now is to capture total number of days he was absent or not present.How can i get the sum of absent days per employee based on given month, as the difficulty is i have to consider 30 days as standard working days for the month , regardless of months having either 30 days (April,June,September,November),or 31(January,March,May,July,August,December) or 28(Consider leap year also february) days.For eg ,If he is absent for 31 days in december then it should consider only 30 days as absent or if he is absent for 28 days in february still it should consider 30 Days as absent.
create table ot_job_det (jt_txn varchar2(12),jt_no number,jt_dt date ,jt_emp_code varchar2(6),jt_duration number )
delete from ot_job_det
[Code].....
I managed to do this with the given query , but this will check only for 31 days and 30 how to consider the february month or any leap year.
SELECT JT_EMP_CODE,DECODE(SIGN(30-COUNT(JT_DT)),-1,30,30-COUNT(JT_DT)) a FROM
OT_JOB_DET WHERE 
TO_CHAR(JT_DT,'YYYYMM')='201212'
GROUP BY JT_EMP_CODE;
	View 16 Replies
    View Related
  
    
	
    	
    	
        Jan 14, 2008
        What I need to do is take 2 dates from a table named 'projects' and insert the number of days between them into a table named 'time_record'.How do I go about this?
	View 1 Replies
    View Related
  
    
	
    	
    	
        Sep 9, 2013
        How can I get count of working days as of given date using SQL? 
	View 6 Replies
    View Related
  
    
	
    	
    	
        Oct 1, 2012
        We have a requirement where we need to pay allowance for the employees based on their number of working days. Say for example if an employee worked from 03/Mar/2012 to 05/Apr/2012. 
We have a fixed value for per month 300 Dirhams. But the Number of Days on March s 31 and Number of days in April is 30. So per day allowance for March day would be 300/31 and April would be 300/30.
We are looking for logic opr query which calculates first eh number of days in each month ( across months) and then calculate as below 
Number of Working days in March is 31 - 3 + 1 = 29 
Allowance A1 = (300 * 29 )/31 
Number of Working days in April is 5 ( this also needs to find logical I am guess ) 
Allowance A2 = (300 * 5 )/30 
Then A1 + A2.
The A(n) would be the total allowance where provided the number of month across.
	View 10 Replies
    View Related
  
    
	
    	
    	
        Nov 13, 2011
        I want function return me how many days Thursday and Friday between two dates.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Apr 18, 2013
        i want to create function to show number of days between to days such as number of Friday days between to dates
	View 13 Replies
    View Related
  
    
	
    	
    	
        Sep 5, 2012
        Is there an Oracle date function that ignores public bank holidays and calculates working days only?
	View 4 Replies
    View Related
  
    
	
    	
    	
        Sep 11, 2010
        In my server , already 10g r2 is installated , now am installaling 11r2, during this, at final stage while running root.sh , it will propmt to override 3 files, oraenv,dbhome .. etc under /usr/local/bin in solaris sys, as these files are already owned by 10g owner ,what i have to select (y or n)?
what if i select y? it will override three files
what if i select n? default option 
	View 2 Replies
    View Related
  
    
	
    	
    	
        Jan 26, 2011
        I want to find the dates which have a date plus with in 2 days after this date. I mean group by 3 days each even the date i missing between two days. Actualy I want to find the start date where the employ was missing on job.
Basic concept is employes have allowed to use 10 personal leaves of a year. Each leave can be use for maximum 3 days. 
If employ did not come on the job for one day or two days or three days, it shoul be count as ONE personal leave. And If employ is missing at job for four or five days, it should be count as 2 personal leaves.
seq              date
------------------------------
101.01.10
205.01.10
306.01.10
410.01.10
512.01.10
613.01.10
714.01.10
815.01.10
916.01.10
1018.01.10
1119.01.10
[Code]...
 
The result should be (Don't use Pl/Sql)
seq              date
------------------------------
101.01.10
205.01.10
310.01.10
413.01.10
516.01.10
619.01.10
723.01.10
826.01.10
929.01.10
After finding these days I want to select the starting date of 5th personal leave. (which is 16.01.10).  
I am not a expert of using SQL, but I think it could be possible with using partitioning a table on the givin reslult and further partition the reslut on rownum() as rn and the using case statement where rn = 5.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Sep 25, 2012
        how to caluclate days between two dates of single timestamp filed and with this
query 
Select * from m_activity_transaction where actn_opp_id in (
Select actn_opp_id from m_activity_transaction where ACTN_ACTV_ID = 218
Group by actn_opp_id
[code]...
and i nedd to caluclate no.of days between two dates like 27-JAN-12 11.06.20.000000 AM and 08-FEB-12 05.32.54.000000 PM where actn_id is unique AND ACTN_OPP_ID IS NOT UNIQUE.
	View 6 Replies
    View Related
  
    
	
    	
    	
        Mar 17, 2011
        I have a query that uses a function to find the business days between two dates.It sums the total number of days between two dates per employee to find the total days for the past 30, 90, or 365 days.
The problem is that the query takes 21 second to return the last 30 days.Over 70 second to return the last 90 days and over 140 second to return the last 365 days.Do you know how I could tune the query to return faster? Below is the query for the last 30 days:
select dwt_emp_id, SUM((SELECT GET_BDAYS(DWT_DATE,DWT_CREATE_DATE) FROM DUAL)) 
from dwt_dvt_work_time where dwt_create_date > sysdate - 30 
and dwt_hours > 4 and dwt_usr_uid_created_by <> -1 group by dwt_emp_id order by dwt_emp_id
Here's the function:
CREATE FUNCTION get_bdays (d1 IN DATE, d2 IN DATE)
   RETURN NUMBER 
   IS total_days NUMBER(11,2);
       holiday_days NUMBER(11,2);
[code]....
	View 1 Replies
    View Related
  
    
	
    	
    	
        May 22, 2010
        The data in one of the temporary table has been compiled as below. Number of Days elapsed between two transaction dates is required to be computed and multiplied with the balance. There can be multiple number of same transaction dates. When previous date and the current transaction dates are same the resulting number of day difference should be 0. But when they are different the difference between them is to be computed. On the last day of the Financial Year i.e. '31/03' of any year the difference day should be shown as 1 so as to make 365 or 366 days in a year. Simply deducting d1 from d2 on 31st will not be suffice as the difference is one day less. 
 ----------------------------------------------------------------------------------------- -------
Transaction Narration                 DebitCreditBalanceNo of DaysProduct
DateDifference
 ----------------------------------------------------------------------------------------- --------
01/04/2009Opening Balance      45020450277346654
17/06/2009ByAmt5044521253424
29/06/2009By Amt1004352156678912
02/12/2009By Amt424310119476000
[code]....
improve the above code and get the desired output result.
	View 5 Replies
    View Related
  
    
	
    	
    	
        Aug 14, 2012
        Is there anyway to show calendar month dates in horizontal line?
First line will have dates and then second line will have day i.e Sat, Sun, Mon.......
1 2 3 4 5 6 7 8 9 ........31
	View 12 Replies
    View Related
  
    
	
    	
    	
        Feb 17, 2010
        I want Oracle stored function/procedure to calculate number of working days between two dates. We need to exclude Firdays and Saturdays as there are weekend holidays and also exclude official holidasy that lie between two dates.
	View 7 Replies
    View Related
  
    
	
    	
    	
        Sep 26, 2012
        I need query to find the missing dates between two columns in given month.
CREATE TABLE emp_shift (
empno NUMBER(4),
fr_date DATE,
TO_DATE DATE,
shift VARCHAR2(1));
CREATE TABLE emp (
empno NUMBER(4)
);
[code].....
Required output is
MISSING_DATES               EMPNO
---------------------- ----------
09-SEP-12 TO 11-SEP-12       7499
23-SEP-12 TO 26-SEP-12       7499
01-sep-12 TO 30-SEP-12       7521
01-sep-12 TO 30-SEP-12       7788
	View 8 Replies
    View Related
  
    
	
    	
    	
        Apr 15, 2011
        I have function that accepts 2 dates namely sDate and eDate i.e start and end dates. See the declaration part of the function:
startDate eab.eod_date%type;
endDate eab.eod_date%type;
begin
 startDate := to_date(sDate,'DD-MON-YY');
 endDate := to_date(eDate,'DD-MON-YY');
end
When I called the function it gives me the following error: ORA-01843: not a valid month..And I tried to simulate the process, the below code also show the same error:
select TO_DATE(to_date('13-DEC-09', 'dd-MON-yy', 'nls_date_language=english'),'DD-moN-YY') from dual;
how I can check that error. I need to pass dates to my function.
	View 8 Replies
    View Related
  
    
	
    	
    	
        Sep 2, 2011
        I have installed Oracle Database 11g.2 by database configuration assistant on windows XP as and adminstrator on my laptop(no connection to network),but when I want to create database I face this warning: error securing database control ,Datatbase control has been brought up in non-secure mode . to secure the database conntrol execute following command....(error is attached).
	View 7 Replies
    View Related
  
    
	
    	
    	
        Apr 5, 2011
        want to write Procedure to return weeks and days from given set of days.
 let suppose we have 72 days to return weeks and days then return should be 7 weeks and 2 days.Can i use date function Or ?
	View 5 Replies
    View Related
  
    
	
    	
    	
        Mar 10, 2011
        Split a date into new dates according to black out dates!
Here is my tables:
CREATE TABLE travel
(
start_date,
end_date
)
AS
SELECT DATE '0000-01-01', DATE '9999-12-31' FROM DUAL;
[code]....
I have lets say a "travel date" and black out dates. I will split the travel date into pieces according to the black out dates.
Note: Travel Date can be between 0000-01-01 - 9999 12 31
Sample:
Travel Date:
Travel | START DATE | END DATE
T      | 2011 01 04 | 2011 12 11
Black Out Dates:
BO   | START DATE | END DATE
A    | 2010 11 01 | 2011 02 11
B    | 2011 01 20 | 2011 02 15
C    | 2011 03 13 | 2011 04 10
D    | 2011 03 20 | 2011 06 29
Excepted Result:
New Travel  | START DATE | END DATE
X1          | 2011 02 16 | 2011 03 12
X2          | 2011 06 30 | 2011 12 11
Visually:
Travel Date : -----[--------------------------]--
A           : --[------]-------------------------
B           : ------[---]------------------------
C           : --------------[---]----------------
D           : ----------------[------]-----------
Result :
X1           : -----------[--]--------------------
X2           : -----------------------[--------]--
Sample 2:
Travel Date  : -[--------------------------------]--
BO Date A    : ----[------]-------------------------
BO Date B    : -------------------------[---]-------
BO Date C    : ----------------[---]----------------
BO Date D    : ------------------[------]-----------
Result X1    : -[-]-------------------------------
Result X2    : -----------[--]--------------------
Result X3    : -----------------------------[--]--
How can I do it using PL SQL ?
	View 5 Replies
    View Related
  
    
	
    	
    	
        May 16, 2013
        Using 11gR2, windows 7 client machine. I need to update the table missing_volume (below), where I need to calculate the estimated_missing column. The calculation of estimated_missing column for current month needs previous month numbers (as commented inside the code below). I want the output like the first table. Notice the records start from January, hence estimated_missing for January can't be calculated, but for the the rest of the months it can be done by simply changing 'yr' and 'mnth' (commented inside the code towards the end).
yr          mnth          location     volume          actual_missing          expected_missing     estimated_missing
---------------------------------------------------------------------------------------------------------------------------------
2013            January          loc1          48037          24               57                         
2013             February     loc1          47960          3660               53                      24
2013             March          loc1          55007          78               57                      28
2013             April          loc1          54345          72               58                  77The code:
UPDATE missing_volume g
[Code]....
The code does calculate correct number for 'estimated_missing' as I run the code for each month, but the problem is while updating the current month it also erases the record for previous month. E.g. as can be seen below, after I updated April the column only has the record for April, previous month record is gone, similarly updating March removed February, etc. I can't understand why it's happening!! Here is the output I get: 
yr          mnth          location     volume          actual_missing          expected_missing     estimated_missing
---------------------------------------------------------------------------------------------------------------------------------
2013            January          loc1          48037          24               57                         
2013             February     loc1          47960          3660               53
2013             March          loc1          55007          78               57
2013             April          loc1          54345          72               58                   77
why it's happening (I mean where is the flaw in the code) and how to get the desired output (first table).
	View 5 Replies
    View Related