SQL & PL/SQL :: Range By Day And Month
			Sep 20, 2010
				I have table :TABLE_X and want to select some data locate into specific range of Day/Month. But so far i couldn't find out the way to.
For example, i want to select people born within specific range of date(range : sysdate to (sysdate+7months ahead) Year here should not be consider, only the  day and month.
e.g. a range could be from today:Sept,20 to Apr,18.
so what i was trying is to select doing the following.
select TABLE_X_ID, TABLE_X_BIRTH_DATE
from TABLE_X
where to_date(TABLE_X_BIRTH_DATE, 'DD/MM')
between to_date (to_char(SYSDATE, 'DD/MM'), 'DD/MM')
and to_date (to_char(SYSDATE+210, 'DD/MM'), 'DD/MM')
first am not sure if BETWEEN & AND will work for this case, bt it was the most logical way i could think about to get such range.
	
	View 13 Replies
  
    
	ADVERTISEMENT
    	
    	
        Mar 3, 2012
        Script to add range partition automatically. This script should be running every month and add the partitions for next 3 months
	View 3 Replies
    View Related
  
    
	
    	
    	
        Mar 28, 2013
        have a req like below
CREATE TABLE TEST_BRK
( EMP_ID VARCHAR2(20),
  BEG_DT DATE,
  END_DT DATE,
  DEPT_CODE VARCHAR2(10),
  
[code]...
  COMMIT;i need to break down the each member range by record per month and make a record as first day of that month . and dept and branch should have the same value as what the value it was in the range of source.
excepted ouput like below 
  EMP_ID      MONTH_DAY_1    DEP_CODE    BRANCH 
  AAAA        01-JAN-2010      02          A
  AAAA        01-FEB-2010      02          A
  AAAA        01-MAR-2010      02          A
  AAAA        01-APR-2010      02          A
  AAAA        01-MAY-2010      02          A
  AAAA        01-JUN-2010      05          B
  AAAA        01-JUL-2010      05          B
  
  .how can i code the logic to get my expected output above
	View 3 Replies
    View Related
  
    
	
    	
    	
        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
  
    
	
    	
    	
        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
  
    
	
    	
    	
        Nov 25, 2010
        I need for each date sum the values from the begin of the year to present date. In January I will have the value of this month, on February I must sum the value of this month and the value of the month before, and so on, at the end of the year.
Date input
SELECT ID_CLIENT, DT_REG, VAL
FROM (
SELECT 1 as ID_CLIENT, TO_DATE('20100101', 'YYYYMMDD') as DT_REG, 200 as VAL FROM DUAL UNION
SELECT 1 as ID_CLIENT, TO_DATE('20100201', 'YYYYMMDD') as DT_REG, 100 as VAL FROM DUAL UNION
SELECT 1 as ID_CLIENT, TO_DATE('20100301', 'YYYYMMDD') as DT_REG, 200 as VAL FROM DUAL UNION
SELECT 1 as ID_CLIENT, TO_DATE('20100401', 'YYYYMMDD') as DT_REG, 150 as VAL FROM DUAL UNION
SELECT 1 as ID_CLIENT, TO_DATE('20100501', 'YYYYMMDD') as DT_REG, 100 as VAL FROM DUAL UNION
SELECT 2 as ID_CLIENT, TO_DATE('20100101', 'YYYYMMDD') as DT_REG, 100 as VAL FROM DUAL UNION
SELECT 2 as ID_CLIENT, TO_DATE('20100301', 'YYYYMMDD') as DT_REG, 220 as VAL FROM DUAL UNION
SELECT 2 as ID_CLIENT, TO_DATE('20100501', 'YYYYMMDD') as DT_REG, 500 as VAL FROM DUAL UNION
SELECT 3 as ID_CLIENT, TO_DATE('20100201', 'YYYYMMDD') as DT_REG, 150 as VAL FROM DUAL UNION
SELECT 3 as ID_CLIENT, TO_DATE('20100501', 'YYYYMMDD') as DT_REG, 100 as VAL FROM DUAL); 
Result
ID_CLIENTDT_REGVAL
101/01/2010200 
101/02/2010300
101/03/2010500
101/04/2010650
101/05/2010750
201/01/2010100
201/03/2010320
201/05/2010820
301/02/2010150
301/05/2010250
	View 17 Replies
    View Related
  
    
	
    	
    	
        Sep 5, 2013
        My goal is to: 
                  A) extract subscriber numbers from TCME153.SUB then
                  B) bounce those subscriber numbers off of a disconnect date i.e. DISCO_DTE_SBB then
                  C) bounce A) and B) off of an item table i.e. ITV_ITEM_VALUE
My hope is that the first query works as intended. Second and third queries throw error 'ORA-01847: DAY OF MONTH MUST BE BETWEEN 1 AND LAST DAY OF MONTH'.
1) SELECT DISTINCT SUB_ACCT_NO_ITV 
    FROM OPS$MDC.ITV_ITEM_VALUE, OPS$MDC.SBB_BASE, TCME153.SUB
    WHERE EXISTS (SELECT SBB_BASE.DISCO_DTE_SBB FROM (SELECT SUB
    FROM TCME153.SUB));
2) SELECT DISTINCT SUB_ACCT_NO_ITV
    FROM OPS$MDC.ITV_ITEM_VALUE, OPS$MDC.SBB_BASE, TCME153.SUB
[Code]....
	View 1 Replies
    View Related
  
    
	
    	
    	
        Jan 21, 2011
        I am trying to query on the dates in the table that are the last day of each month. The last day of the month may not be in the table. Example 07/30/2010 is the last day in the table for July 2010, but 07/31/2010 is the last day of the month. My query should give me 07/30/2010 data since it is the last day of the month in the table.
I just need a where clause that will only give me the data for the last day of each in the table.
	View -1 Replies
    View Related
  
    
	
    	
    	
        Jun 10, 2010
        i want to get the last month  starting from today onwards.
1) select the record  of last month that is if this month is june then select the record for 1st may to 31st of may
	View 7 Replies
    View Related
  
    
	
    	
    	
        Sep 25, 2012
        I am facing a problem to find the last day of the month which is stored in a variable. i tried the following query which gave me an appropriate answer
select to_char(last_day(sysdate),'DD-MON-YY')from dual
ans : 30-SEP-2012
But I am having only the month in my hand through which I want to find its last day. I cant use sysdate for my query.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Dec 6, 2010
        I need to calculate first business day of a given month . Below is complete explanation
Business day=sould not include weekends and holidays.
In a table say ACTIVITY_XX I have all the month begin dates say 01-JAN-2010,01-FEB-2010,01-MAR-2010,01-APR-2010 and so on..and I have a HOLIDAY table where all the holidays are stored.
So using the above info I need to calculate the first business day for a given month. I guess this cannot be done by using a simple SQL query? I was wondering how could it be written using a PL/SQL function.
I'll be passing the month begin date as parameter..so the function should return the first business day for that month.
	View 16 Replies
    View Related
  
    
	
    	
    	
        Oct 26, 2010
        How to find the total number of Thursday in the current month ?
	View 5 Replies
    View Related
  
    
	
    	
    	
        Jun 20, 2012
        I've got a TRANSACTION table with about 4, 681 transactions going on over the course of a given year (this is a project for my DB class). I'm trying to create a query that will give the base revenue for each month in that year; so far I've come up with the following:
SELECT DISTINCT 
CASE
WHEN EXTRACT(MONTH FROM transaction_date) = 1 THEN 'JAN' || ' ' || EXTRACT(YEAR FROM transaction_date)
WHEN EXTRACT(MONTH FROM transaction_date) = 2 THEN 'FEB' || ' ' || EXTRACT(YEAR FROM transaction_date)
WHEN EXTRACT(MONTH FROM transaction_date) = 3 THEN 'MAR' || ' ' || EXTRACT(YEAR FROM transaction_date)
WHEN EXTRACT(MONTH FROM transaction_date) = 4 THEN 'APR' || ' ' || EXTRACT(YEAR FROM transaction_date)
[code]....
The query returns twelve months, but they're all jumbled up. I tried extracting the month in the ORDER BY subclause 
ORDER BY EXTRACT(MONTH FROM TO_DATE(month, 'MM YYYY'));
But I got an ORA-01866: the datetime class is invalid. I'm using Oracle 10g xe (outdated, I know). get the months to show up in order?
	View 7 Replies
    View Related
  
    
	
    	
    	
        Jan 31, 2013
        How I can see the order by employees,year wise and monthwise (month should start from january and so on..)
SELECT ENAME,TO_CHAR(HIREDATE,'yyyy') YEAR,TO_CHAR(HIREDATE,'Month') MONTH ,count(*) total
FROM EMP
GROUP BY TO_CHAR(HIREDATE,'yyyy') ,TO_CHAR(HIREDATE,'Month');
	View 8 Replies
    View Related
  
    
	
    	
    	
        Mar 26, 2012
        I have a table with the following fields :
 RGS_CAN_PERIOD                           NUMBER(4)
 RGS_ID_ELECTOR                           NUMBER(
 FBD_NID                                  VARCHAR2(14)
 RGS_SURNAME                              VARCHAR2(40)
 RGS_O_NAME                               VARCHAR2(40)
 RGS_ALIAS                                VARCHAR2(30)
 RGS_ADDR                                 VARCHAR2(75)
 RGS_ID_REG_AREA                          VARCHAR2(3)
[Code]..
I need  a report as hereunder :
Reg. Area  Age <=19   20 <= Age <= 24  25 <=Age <= 29 Total No. of Voters
xxxx         10             15             7                   32
yyyy          5              7              3                  15 
I have work out a script but the age is not in a range
select * 
FROM (select rgs_id_reg_area, 
       count(decode(fbd_age,19,fbd_age)) Age19, 
   count(decode(fbd_age,20,fbd_age)) Age20 
FROM rubyvoterstat where vote ='Y' 
GROUP by rgs_id_reg_area) 
order by rgs_id_reg_area
	View 1 Replies
    View Related
  
    
	
    	
    	
        Dec 5, 2011
        In my prod table few partition need to be added. 
I tried below both syntax, but I am getting error
1) 
Alter table STS.DNA_ACCESSION add PARTITION DNA_ACC_P143 VALUES LESS THAN (286000000);
ORA-14074: partition bound must collate higher than that of the last partition
2)
ALTER TABLE STS_RO.DNA_ACCESSION
SPLIT PARTITION DNA_ACC_P999 AT VALUES LESS THAN (286000000)
INTO (PARTITION DNA_ACC_P143,
[Code]....
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jun 12, 2012
        I have a table like this:
x     y     AMNT
---------------------------------------
1     120     12
1     120     93
1     125     31
1     260     15
2     56     16
2     115     49
3     45     71
4     19     11
4     16     48
5     94     52
5     98     47
I want to group records on x , y columns and aggregate on amnt column, in which difference between values of y column be less than 10.
The result is like this:
x     y     sum(AMNT)
------------------------------------------------
1     ?     136
1     260     15
2     56     16
2     115     49
3     45     71
4     ?     59
5     ?     99
What query can I use?
	View 6 Replies
    View Related
  
    
	
    	
    	
        Aug 13, 2010
        Past 13 MonthEnds from a input date 
(i.e.: 6/13/2010 is supplied, then query should be able to retrieve  5/31/2010, 4/30/2010, 3/31/2010, 2/26/2010, 1/29/2010, 12/31/2009?.....5/29/2009)
If the month end date falls on a weekend (Sat or Sun), then it should have the prior Friday's date.
	View 18 Replies
    View Related
  
    
	
    	
    	
        Apr 8, 2013
        have this SQL query works fine but I want to calculate the balances for each month...I STARTING to do so: I have to:
JanuaryBalance = Initialbalance + January;
FebruaryBalance = JanuaryBalance+February;
MarchBalance = FebruaryBalance + March;
SELECT
Sum("F0902"."GBAPYC"/100) AS "initialBalance",
Sum("F0902"."GBAN01"/100) AS "January",
Sum("F0902"."GBAN02"/100) AS "February",
Sum("F0902"."GBAN03"/100) AS "March",
[code]....
	View 10 Replies
    View Related
  
    
	
    	
    	
        Jun 25, 2010
        can we take the maximum and minimum value of month and year
	View 7 Replies
    View Related
  
    
	
    	
    	
        Feb 13, 2013
        How to find out first thursday for each month in year.
	View 7 Replies
    View Related
  
    
	
    	
    	
        Jan 28, 2011
        getting the following kind of output.
I would like to get Each year and the number of employees joined in the corresponding month for jan, feb, mar and april from emp table.
A sample output looks like below.
YEAR JAN FEB MAR APRIL
2000  4   2   1   2
2001  2   1   1   5
2002  2   4   2   6  
2004  2   4   1   4  
	View 7 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
  
    
	
    	
    	
        Aug 17, 2011
        I have the following table. In this table i'm trying to get the count of records by month when its value (SIGNAGE_ONE_LANE_ROAD_AHEAD) is 'Yes' and its giving me the wrong count. 
AUDIT_DATE SIGNAGE_ONE_LANE_ROAD_AHEAD SIGNAGE_LANE_CLOSED_AHEAD
1/5/2011 9:30 N/A N/A
2/9/2011 11:50 Yes Yes
2/21/2011 10:00 Yes Yes
2/22/2011 7:00 N/A N/A
3/7/2011 13:35 Yes N/A
3/8/2011 9:15 N/A N/A
3/9/2011 8:40 N/A N/A
3/10/2011 10:00 N/A N/A
[code]....
	View 15 Replies
    View Related
  
    
	
    	
    	
        Mar 8, 2011
        I need to get data from a table in which dates is equal from previous month. The dates in this table has a formula DD-MMM-YY (CRE_DTTM is the name for date column). 
I've already achieve getting data from the previous month by using this formula:
(to_char(CRE_DTTM,'MON')) = UPPER(to_char(add_months(trunc(sysdate,'MONTH'),-1), 'Mon'))
My problem now is what if the current month is for example JAN 2011.. I need to get the data from DEC 2010. How can I query the previous year in this case?
	View 10 Replies
    View Related
  
    
	
    	
    	
        Mar 20, 2011
        I have two  Queries.
Query 1:
SELECT DISTINCT YR FROM(
SELECT TO_CHAR( ADD_MONTHS (TRUNC (TO_DATE('01/01/2007'  ,'DD/MM/YYYY'), 'YYYY'), 1*LEVEL -1) , 'YYYY') 
YR   FROM Dual
CONNECT BY LEVEL <= MONTHS_BETWEEN(TO_DATE(:to_dt  ,'DD/MM/YYYY'), TO_DATE('01/01/2007' ,'DD/MM/YYYY')) + 1
ORDER BY YR
)
Gives the Output as
YR
****
2007
2008
2009
2010
2011
Query 2
*******
SELECT DISTINCT MONTH FROM(
SELECT TO_CHAR( ADD_MONTHS (TRUNC (TO_DATE('01/01/2007'  ,'DD/MM/YYYY'), 'MM'), 1*LEVEL -1) , 'MM') 
MONTH   FROM Dual
CONNECT BY LEVEL <= MONTHS_BETWEEN(TO_DATE(:to_dt  ,'DD/MM/YYYY'), TO_DATE('01/01/2007' ,'DD/MM/YYYY')) + 1
ORDER BY MONTH
)
Gives the Output as 
MONTH
***
01
02
03
04
05
06
07
08
09
10
11
12
I want to combine these two. I need the output as
2007-01
2007-02
2007-03
....
...
	View 8 Replies
    View Related
  
    
	
    	
    	
        Jul 25, 2011
        I have a date field with varchar datatype. My data look like :
ID Amend_DATE
1   4/24/1974
1   4/18/2001
1   8/2/1971
2   8/4/1965
3   11/9/2001
4   8/15/2001
I need to find the minimum amend_date for each ID.When i calculate min(amend_date), it gives me error:
ORA-01843 : not a valid month
Query i am using is :
select min(to_date(amend_date ,'mm/dd/yyyy') )   from t group by id;
My data on application appears as 24 April 1974.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Sep 14, 2012
        I have 2 cursors. Cursor 1 selects a number and 2 dates (values in the Table are in the format mm/dd/yyyy for both the columns).
I pass these values to Cursor 2.
v_promotion_id                    promotion.promotion_id%TYPE;
v_promotion_start_date        promotion.start_date%TYPE;
v_promotion_end_date          promotion.end_date%TYPE;
CURSOR c_promotion_list IS
(SELECT DISTINCT p.promotion_id,
p.start_date - 5,
p.end_date + 5
FROM promotion p,
[code]....
I am getting this error: ORA-01843: not a valid month
Initially I was passing just the variables without To_date. But I got the same error.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Sep 17, 2013
        find the last nth month name [Single month].
	View 5 Replies
    View Related