Jump to content

Recommended Posts

thx John ,,,

but u'r query result only one output

 

i mean i need it  Total Rain every (10-day) for all long data such from year 2000 to 2012

so the output will be like this

 

TIME                Rain

tenday-1          10

tenday-2          5

tenday-3          32

,

,

,

 

any more idea ???

Are the 10-day periods like those in "A" below or like "B" ?

January

1        10        20        30

---------|---------|---------|-

 

**********

          **********              (A)

                    **********

                   

**********

**********                        (B)

  **********

  **********

almost like that Barrand

10-day ecaxtly like this

 

January ;

1 ------- 10

11 -------20

21 -------31 (end of month)

 

February ;

1--------10

11------20

21------28 or 29 (the end of the month)

 

the last 10-days is not always 10 day ,,, depend on the month

 

thx ,

any idea ??

 

I wrote this query last night, but my grandson flipped off the power strip and it was lost. I think it went something like this:

 

SELECT FLOOR(DATE_DIFF(RainDate, '2011-01-01') / 10) AS RainSet,
	SUM(RainQty) AS TotalRain
FROM dayRain
WHERE RainDate BETWEEN '2011-01-01' AND '2011-01-31'
GROUP BY 1

 

  • DATE_DIFF(RainDate, '2011-01-01') calculates the number of days between the date in the table and the starting date of your range. For the first date in your range, this is zero
  • FLOOR( <DATE_DIFF> / 10) - Divides that number of days by 10 and returns an integer result. So the first ten days will have a RainSet value of zero, the next 10 days will have a RainSet value of 1, etc.
  • GROUP BY 1 - groups by the first expression in the select list (this is a shortcut so I don't have to type the whole FLOOR(DATE_DIFF ...) expression again

 

The Date in the DATE_DIFF expression needs to be the start date of your range. Your range is also specified in the WHERE clause --- remember BETWEEN is inclusive.

 

This will return a result set like:

RainSet  TotalRain
-------  -------
0        20
1        5
2        15

 

 

i need to make a new table but tendays period ,,,

 

The beauty of relational databases and SQL, is that you almost never "need" to make a new table for calculated data. Unless you have a compelling reason to create the table, you should use queries to summarize your data.

This should do the whole year in one go

SELECT YEAR(raindate)as year, MONTH(raindate)as Month, 0 as dayset, SUM(rainqty) as rainfall
FROM dayrain
WHERE DAYOFMONTH(raindate) BETWEEN 1 AND 10
GROUP BY year, Month
UNION
SELECT YEAR(raindate)as year, MONTH(raindate)as Month, 1 as dayset, SUM(rainqty) as rainfall
FROM dayrain
WHERE DAYOFMONTH(raindate) BETWEEN 11 AND 20
GROUP BY year, month
UNION
SELECT YEAR(raindate)as year, MONTH(raindate)as Month, 2 as dayset, SUM(rainqty) as rainfall
FROM dayrain
WHERE DAYOFMONTH(raindate) BETWEEN 21 AND 31
GROUP BY year, month
ORDER BY year, month, dayset

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.