overlap query where to and from can be same ( of next and previous range)

  • hi,

    we are entering range like

    pointfrom pointto

    1 5

    5 6

    7 9

    10 11

    11 12

    to find overlap i use

    (@pointfrom >= A.ChainageFrom AND @pointfrom <= A.ChainageTo) OR

    (@pointto >= A.ChainageFrom AND @pointto <= A.ChainageTo) OR

    (A.ChainageFrom >= @pointfrom AND A.ChainageFrom < =@pointto) OR

    (A.ChainageTo >= @pointfrom AND A.ChainageTo <= @pointto)

    but this time requirement is pointfrom can > or = to previous "range's pointto" or pointto can be < or = to next range's pointfrom

    (@pointfrom >= A.ChainageFrom AND @pointfrom < A.ChainageTo) OR

    (@pointto > A.ChainageFrom AND @pointto <= A.ChainageTo) OR

    (A.ChainageFrom >= @pointfrom AND A.ChainageFrom < @pointto) OR

    (A.ChainageTo > @pointfrom AND A.ChainageTo <= @pointto)

    yours sincerley

  • Is there a question in here, or are you just sharing what you did?

    If there is a question, then please post:

    * CREATE TABLE statements for the table

    * INSERT statements with a few rows of sample data

    * Expected results, with an explanation

    * The work you have done so far, its results, and what you are strill struggling with


    Hugo Kornelis, SQL Server/Data Platform MVP (2006-2016)
    Visit my SQL Server blog: https://sqlserverfast.com/blog/
    SQL Server Execution Plan Reference: https://sqlserverfast.com/epr/

  • is the second one correct or not.

    i have to find out where it is overlapping in second case.

    Pointfrom and pointto is passed in query as param.

    where point from is always < point to

    create table #t (f int, t int)

    insert into #t values (1,5)

    insert into #t values (5,6)

    insert into #t values (7,9)

    insert into #t values (10,11)

    insert into #t values (11,12)

    select * from

    (@pointfrom >= A.f AND @pointfrom < A.t) OR

    (@pointto > A.f AND @pointto <= A.t) OR

    (A.f>= @pointfrom AND A.f< @pointto) OR

    (A.t> @pointfrom AND A.t <= @pointto)

    yours scincerley

  • rajemessage 14195 (2/12/2016)


    is the second one correct or not.

    i have to find out where it is overlapping in second case.

    Your description is unclear. Are you able to introduce clarity by providing the details requested by Hugo?

    The absence of evidence is not evidence of absence.
    Martin Rees

    You can lead a horse to water, but a pencil must be lead.
    Stan Laurel

  • --requirement is pointfrom can > or = to previous "range's pointto" or pointto can be < or = to next range's pointfrom

    --@Pointfrom and @pointto is passed in query as param.

    --where pointfrom is always < pointto

    create table #t (f int, t int)

    insert into #t values (1,5)

    insert into #t values (5,6)

    insert into #t values (7,9)

    insert into #t values (10,11)

    insert into #t values (11,12)

    declare @pointfrom int, @pointto int

    select @pointfrom=1 , @pointto=2

    select * from #t as a where

    (@pointfrom >= A.f AND @pointfrom < A.t) OR

    (@pointto > A.f AND @pointto <= A.t) OR

    (A.f>= @pointfrom AND A.f< @pointto) OR

    (A.t> @pointfrom AND A.t <= @pointto)

  • So what exactly is the expected output from the sample data you posted? And what exactly is the problem with the query you posted?


    Hugo Kornelis, SQL Server/Data Platform MVP (2006-2016)
    Visit my SQL Server blog: https://sqlserverfast.com/blog/
    SQL Server Execution Plan Reference: https://sqlserverfast.com/epr/

  • where ever @pointfrom and @pointTo is overlaping with records ,considering the given critaria should come.

  • rajemessage 14195 (2/12/2016)


    where ever @pointfrom and @pointTo is overlaping with records ,considering the given critaria should come.

    Provide the output you expect, based on the data you provided.

    Not an English explanation of the output, but the actual data.

    The absence of evidence is not evidence of absence.
    Martin Rees

    You can lead a horse to water, but a pencil must be lead.
    Stan Laurel

  • --

    -- Create a table with content. (Containing periods of hours, days, months and 24 hour periods)

    --

    DECLARE @test_a table(a_start datetime

    , a_stop datetime

    , aname varchar(300))

    insert into @test_a VALUES('20160202','20160203','One day')

    ,('20160203','20160204','Next day')

    ,('20160201','20160202','previous day')

    ,('20160201 23:59:59.999','20160202 23:59:59.999','which day is this')

    ,('20160203 15:00','20160204 15:00','24 hours')

    ,('20160201','20160301','One month')

    ,('20160203 14:00','20160203 15:00','One Hour')

    ,('20160203 15:00','20160203 16:00','Next Hour')

    --

    -- Create a second table. (With the same content

    --

    DECLARE @test_b table(b_start datetime, b_stop datetime, bname varchar(300))

    insert into @test_b select * from @test_a

    -- Code similar to rajemessage 14195

    select * from @test_a cross join @test_b where

    (

    (b_start >= a_start AND b_start <= a_stop) OR

    (b_stop >= a_start AND b_stop <= a_stop) OR

    (a_start >= b_start AND a_start < =b_stop) OR

    (a_stop >= b_start AND a_stop <= b_stop)

    ) and aname <> bname

    -- Code similar to rajemessage 14195

    select * from @test_a cross join @test_b where

    (

    (b_start >= a_start AND b_start < a_stop) OR

    (b_stop > a_start AND b_stop <= a_stop) OR

    (a_start >= b_start AND a_start < b_stop) OR

    (a_stop > b_start AND a_stop <= b_stop)

    ) and aname <> bname

    ---------------------------------------------------------------------------------

    -- Use one of the following constructions : --

    ---------------------------------------------------------------------------------

    -- Non overlapping:

    select * from @test_a cross join @test_b where

    (a_stop <= b_start or b_stop <= a_start) and aname <> bname

    -- Overlapping

    select * from @test_a cross join @test_b where

    NOT (a_stop <= b_start or b_stop <= a_start) and aname <> bname

    ------------------------------------------------------------------------------------------------

    -- Overlapping simplyfied: (Preferred syntax).

    select * from @test_a cross join @test_b where

    (a_stop > b_start AND b_stop > a_start) and aname <> bname

    ------------------------------------------------------------------------------------------------

    --

    -- Overlapping simplyfied:

    -- Overlap is true when stop and start are the same.

    --

    select * from @test_a cross join @test_b where

    (a_stop >= b_start AND b_stop >= a_start) and aname <> bname

    The above code shows how to test for overlapping or non overlapping.

    You can define that there should be a gap between two datetimes.

    A datetime field should be considered a point in time. It can be a starting point of for example a day a month or a 24 hour period, but this should be defined exactly beforehand. Otherwise it should be considered a point in time.

    For overlap you can define that there should be a gap between two periods. Which is the last example.

    If the stop time is dat date and this is defined as an inclusive date. 1 should be added to the date to get the end of the date. I myself consider this a bad usage of a datetime field. Because then the period ends 24 hours after the point in time given by the stop date.

    --

    -- If the stop date is not a time but a date including the date self.

    -- A day should be added to the stop date.

    -- This works for dates, but also for times where 24 hours is added.

    --

    -- Overlapping (stop day inclusive):

    --

    select * from @test_a cross join @test_b where

    (dateadd(day,1,a_stop) > b_start AND dateadd(day,1,b_stop) > a_start) and aname <> bname

    This code is less generic, because suppose the time is given in hours and not in days, in that case an hour should be added. Suppose the time is given in minutes and not in hours, in that case a minute should be added. Same for seconds. But also the same for years, months, weeks etc.

    It is far better to define the endtime (stop) as the point in time where the period stops.

    (Edit) Your query (for overlap) would become:

    (A.ChainageTo > @pointto AND @pointfrom > A.ChainageFrom)

    (Edit) Your query (for NON overlap) would become:

    (A.ChainageTo <= @pointto OR @pointfrom <= A.ChainageFrom)

    Please inform us if this helps.

    Ben

    < should be read as < (The site is changing this ???)

    > should be read as >

    *)

    The table_b can be replaced by again the table_a or with parameters or constants.

  • i want all records from #t

    which are overlaping with entered @pointfrom = 2 and @pointTo = 10

    --requirement is "f" can > or = to previous "range's "t" or "t" can be < or = to next range's "f"

    --"f" is always less than "t"

    --@Pointfrom and @pointto is passed in query as param.

    --where @pointfrom is always < @pointto

    create table #t (f int, t int)

    insert into #t values (1,5)

    insert into #t values (5,6)

    insert into #t values (7,9)

    insert into #t values (10,11)

    insert into #t values (11,12)

    declare @pointfrom int, @pointto int

    select @pointfrom=1 , @pointto=2

    select * from #t as a where

    (@pointfrom >= A.f AND @pointfrom < A.t) OR

    (@pointto > A.f AND @pointto <= A.t) OR

    (A.f>= @pointfrom AND A.f< @pointto) OR

    (A.t> @pointfrom AND A.t <= @pointto)

    yours sincerley

  • For your last example:

    select * from #t as a where

    A.t > @pointfrom AND @pointto > A.f

    Ben

  • rajemessage 14195 (2/12/2016)


    i want all records from #t

    which are overlaping with entered @pointfrom = 2 and @pointTo = 10

    Since you are unwilling to provide the very simple answer we asked you, multiple times, I am done in this topic.

    Good luck with your issue. I really hope that you do find someone who is able and willing to help you based on your vague and incomplete explanations. And I truly hope that the answer they provide will actually work and not backfire.


    Hugo Kornelis, SQL Server/Data Platform MVP (2006-2016)
    Visit my SQL Server blog: https://sqlserverfast.com/blog/
    SQL Server Execution Plan Reference: https://sqlserverfast.com/epr/

  • Okay, since you insist on us taking a shot in the dark, here is mine:

    '

    -- Using your sample data posted above

    declare @pointfrom int = 2,

    @pointto int = 10;

    select * from #t;

    select a.*

    from #t a

    where

    a.t >= @pointfrom and

    a.f <= @pointto;

    Output from the first query:

    ft

    15

    56

    79

    1011

    1112

    Output from the second query: -- is this what you are looking for?

    ft

    15

    56

    79

    1011

  • rajemessage 14195 (2/12/2016)


    [font="Arial Black"]i want all records from #t

    which are overlaping with entered @pointfrom = 2 and @pointTo = 10[/font]

    --requirement is "f" can > or = to previous "range's "t" or "t" can be < or = to next range's "f"

    --"f" is always less than "t"

    --@Pointfrom and @pointto is passed in query as param.

    --where @pointfrom is always < @pointto

    create table #t (f int, t int)

    insert into #t values (1,5)

    insert into #t values (5,6)

    insert into #t values (7,9)

    insert into #t values (10,11)

    insert into #t values (11,12)

    declare @pointfrom int, @pointto int

    select @pointfrom=1 , @pointto=2

    select * from #t as a where

    (@pointfrom >= A.f AND @pointfrom < A.t) OR

    (@pointto > A.f AND @pointto <= A.t) OR

    (A.f>= @pointfrom AND A.f< @pointto) OR

    (A.t> @pointfrom AND A.t <= @pointto)

    yours sincerley

    Using the #t test table from above, the answer is remarkably simple... like this.

    --===== Declare variables as you did before

    DECLARE @PointFrom INT

    ,@PointTo INT

    ;

    SELECT @PointFrom = 2

    ,@PointTo = 10

    ;

    --===== The solution is surprisingly simple

    SELECT *

    FROM #t

    WHERE t >= @PointFrom

    AND f <= @PointTo

    ;

    For more information on how and why the code works, please see the following article.

    [font="Arial Black"]http://www.sqlservercentral.com/articles/T-SQL/105968/[/font][/url]

    [font="Arial Black"]EDIT: Just noticed that Lynn posted almost exactly the same code.[/font]

    Well done on your "shot in the dark", Lynn. 🙂

    [font="Arial Black"]EDIT EDIT: Also just noticed that Ben was also right there (excluding exact matches).[/font] That's what I get for not reading further down. :blush:

    --Jeff Moden


    RBAR is pronounced "ree-bar" and is a "Modenism" for Row-By-Agonizing-Row.
    First step towards the paradigm shift of writing Set Based code:
    ________Stop thinking about what you want to do to a ROW... think, instead, of what you want to do to a COLUMN.

    Change is inevitable... Change for the better is not.


    Helpful Links:
    How to post code problems
    How to Post Performance Problems
    Create a Tally Function (fnTally)

  • Jeff Moden (2/12/2016)


    [font="Arial Black"]EDIT EDIT: Also just noticed that Ben was also right there (excluding exact matches).[/font] That's what I get for not reading further down. :blush:

    Yeah, that's what you get when you want to help people, but also want to use your time efficiently.

    With your valuable help, this is bound to happen once in a while.

    So this happened because of your helpfullness.:-D:-D:-D

    So we had some overlap in our anwsers, just being true to the question.

    ben

    (In a previous anwser I explained why the exact matches are excluded. It is my strong preverence, I did include some code there how I normally tread this sort of things.)

Viewing 15 posts - 1 through 15 (of 19 total)

You must be logged in to reply to this topic. Login to reply