Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 6570591
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 25, 20262026-05-25T14:46:30+00:00 2026-05-25T14:46:30+00:00

Below is the given table data: CREATE TABLE #tbl_period ( period_no INT, period_from SMALLDATETIME,

  • 0

Below is the given table data:

CREATE TABLE #tbl_period (
    period_no INT,
    period_from SMALLDATETIME,
    period_to SMALLDATETIME
)

INSERT INTO #tbl_period (period_no, period_from, period_to)
VALUES (1, '2004-11-01 00:00:00', '2005-10-31 00:00:00')

INSERT INTO #tbl_period (period_no, period_from, period_to)
VALUES (2, '2005-11-01 00:00:00', '2006-10-31 00:00:00')

INSERT INTO #tbl_period (period_no, period_from, period_to)
VALUES (3, '2006-11-01 00:00:00', '2007-10-31 00:00:00')

INSERT INTO #tbl_period (period_no, period_from, period_to)
VALUES (4, '2007-11-01 00:00:00', '2008-10-31 00:00:00')

INSERT INTO #tbl_period (period_no, period_from, period_to)
VALUES (5, '2008-11-01 00:00:00', '2009-10-31 00:00:00')

INSERT INTO #tbl_period (period_no, period_from, period_to)
VALUES (6, '2009-11-01 00:00:00', '2010-10-31 00:00:00')

INSERT INTO #tbl_period (period_no, period_from, period_to)
VALUES (7, '2010-11-01 00:00:00', '2011-10-31 00:00:00')

SELECT * FROM #tbl_period

DROP TABLE #tbl_period

Now, The goal is to retrieve the period_no which having 2 given dates who will be compared to period_from and period_to columns.

Example1:
date1 = '2010-11-01 00:00:00'
date2 = '2011-10-31 00:00:00'

This will return 7 as the period_no

Example2: 
date1 = '2005-11-01 00:00:00'
date2 = '2007-10-31 00:00:00'

It should not return a period_no because the date range given does not in the range of period_from and period_to column in a row. Overlap dates is not allowed.

The rule is to retrieve a period_no if the 2 given date will have a match or be in a range of period_from and period_to column in a row.

How to do this query in T-SQL?

Thanks in advance!

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-25T14:46:30+00:00Added an answer on May 25, 2026 at 2:46 pm

    I reckon this is what you’re after:

    SELECT 
        *
    FROM 
        #tbl_period 
    WHERE 
        @date1 >= period_from 
        and
        @date2 <= period_to
    

    Tests:

    declare @date1 datetime = '2010-11-01 00:00:00' 
    declare @date2 datetime = '2011-10-31 00:00:00' 
    
    SELECT * FROM #tbl_period WHERE @date1 >= period_from and @date2 <= period_to
    

    returns

    period_no    period_from          period_to
    7            2010-11-01 00:00:00  2011-10-31 00:00:00
    

    and

    set @date1 = '2005-11-01 00:00:00' 
    set @date2 = '2007-10-31 00:00:00' 
    
    SELECT * FROM #tbl_period WHERE @date1 >= period_from and @date2 <= period_to
    

    returns

    period_no   period_from period_to
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have a table with data as given below: DATE Price ---------- ------ 31/12/2009
I have a organization name table with the following structure given below: CREATE TABLE
Given the one-table design given below how would the following best be queried The
Given the following html table and script shown below I am having a problem
A query (see below) that extracts climate data from weather stations within a given
I have created a table using below mensioned query in MySQL. CREATE TABLE Pat_Visit
I was asked the following Question: How would you store the data given below(which
Currently have : LOAD DATA LOCAL INFILE '/Users/RkG/Desktop/Microblogs.csv' INTO TABLE blogs This is an
I have an ai_order table. CREATE TABLE `ai_order`( `id` INT(11) NOT NULL AUTO_INCREMENT, `product_id`
What is the use of the below given tables in Joomla Database? jos_core_acl_aro jos_core_acl_aro_groups

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.