View previous topic :: View next topic |
Author |
Message |
balaji.p.raman Beginner
data:image/s3,"s3://crabby-images/13d2f/13d2faa6e0e09d90bafb6c753b5a027485ad7286" alt=""
Joined: 27 Feb 2007 Posts: 10 Topics: 5 Location: India
|
Posted: Fri Aug 08, 2008 12:32 am Post subject: Fetch first few bytes from an Integer field |
|
|
Hi,
I have an integer field in my table where I store the date in YYYYMMDD format. I have a requirement now to fetch the rows that falls on a particular year and particular month. The month field however is not mandatory.
I am thinking putting a query which uses BETWEEN YYYYMM01 and YYYYMM31.
I am curious to know is there any other way to achieve the same result.
Again, I couldnt find out whether this has been already posted.
Please forgive if already posted _________________ Rgds,
Balaji |
|
Back to top |
|
data:image/s3,"s3://crabby-images/fcd6a/fcd6a401f80939b790c230f23a6985d7c8135d59" alt="" |
shantharam_k Beginner
Joined: 03 Feb 2007 Posts: 4 Topics: 0
|
Posted: Fri Aug 08, 2008 2:21 am Post subject: |
|
|
Using BETWEEN is probably the best bet for you.
However, any idea on why the filed is defined as INT? There is no gain in terms of space as both use 4 bytes. And u need to carry the extra overhead of validating the data before insertion (for ex. you can insert a value of 20080230 into this INT fileld which would fail if it were a DATE). Also take caution before insertion of data so that leading zeroes in the MM and DD fields are not lost. Else you may end up with catastrophic results. data:image/s3,"s3://crabby-images/4656f/4656fbd603d268694f77eba5ea0f9403b758aa85" alt="Shocked" |
|
Back to top |
|
data:image/s3,"s3://crabby-images/fcd6a/fcd6a401f80939b790c230f23a6985d7c8135d59" alt="" |
seekaysk Beginner
Joined: 31 Aug 2007 Posts: 49 Topics: 15
|
Posted: Mon Aug 11, 2008 9:18 am Post subject: |
|
|
Balaji, you could use YEAR and MONTH scalar functions. However, they depreciate the performance of your query is it is too critical. otherwise, that should give you hte results.
select * from table where year(column1) = 2000 and month(column1) = 01 _________________ Thanks. |
|
Back to top |
|
data:image/s3,"s3://crabby-images/fcd6a/fcd6a401f80939b790c230f23a6985d7c8135d59" alt="" |
CraigG Intermediate
Joined: 02 May 2007 Posts: 202 Topics: 0 Location: Viginia, USA
|
Posted: Mon Aug 11, 2008 10:34 am Post subject: |
|
|
seekaysk wrote: | Balaji, you could use YEAR and MONTH scalar functions. However, they depreciate the performance of your query is it is too critical. otherwise, that should give you hte results.
select * from table where year(column1) = 2000 and month(column1) = 01 |
YEAR and MONTH only work with columns defined as DATE or TIMESTAMP! |
|
Back to top |
|
data:image/s3,"s3://crabby-images/fcd6a/fcd6a401f80939b790c230f23a6985d7c8135d59" alt="" |
seekaysk Beginner
Joined: 31 Aug 2007 Posts: 49 Topics: 15
|
Posted: Mon Aug 11, 2008 12:07 pm Post subject: |
|
|
oh, my apologies. i might have not read the complete req. now I get ti's an INT column. _________________ Thanks. |
|
Back to top |
|
data:image/s3,"s3://crabby-images/fcd6a/fcd6a401f80939b790c230f23a6985d7c8135d59" alt="" |
|
|