select document based on date range












0















Structure



CREATE TABLE `template` (
`name` VARCHAR(16) NOT NULL COLLATE 'utf8_unicode_ci',
`valid` DATE NULL DEFAULT NULL,
UNIQUE INDEX `name` (`name`)
)
COLLATE='utf8_unicode_ci'
ENGINE=InnoDB;


Data



enter image description here



I am trying to select right template name based on date. "Valid" column represents date till template is valid. If Template have 0000-00-00 or NULL valid date, that means that this template is current (latest). Template names does not suggest order (they can be random string).



Scenario:



If I have user, that will be created let's say 2010-01-01, then select should pick template with name "yes_4".



Scenario:



User was created in 2018-01-01, then template selected should have name "agreement_x"



Scenario:



User created in 2019-01-15 will select row with name "template_2"



So far:



:date = - user created


query



SELECT * FROM `template` 
WHERE DATE(`valid`) < DATE(:date)
ORDER BY DATE(`valid`) DESC
LIMIT 1









share|improve this question







New contributor




Ing. Michal Hudak is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.





















  • 2010-01-01 ... template with name "yes_4". WHY???

    – Akina
    9 mins ago
















0















Structure



CREATE TABLE `template` (
`name` VARCHAR(16) NOT NULL COLLATE 'utf8_unicode_ci',
`valid` DATE NULL DEFAULT NULL,
UNIQUE INDEX `name` (`name`)
)
COLLATE='utf8_unicode_ci'
ENGINE=InnoDB;


Data



enter image description here



I am trying to select right template name based on date. "Valid" column represents date till template is valid. If Template have 0000-00-00 or NULL valid date, that means that this template is current (latest). Template names does not suggest order (they can be random string).



Scenario:



If I have user, that will be created let's say 2010-01-01, then select should pick template with name "yes_4".



Scenario:



User was created in 2018-01-01, then template selected should have name "agreement_x"



Scenario:



User created in 2019-01-15 will select row with name "template_2"



So far:



:date = - user created


query



SELECT * FROM `template` 
WHERE DATE(`valid`) < DATE(:date)
ORDER BY DATE(`valid`) DESC
LIMIT 1









share|improve this question







New contributor




Ing. Michal Hudak is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.





















  • 2010-01-01 ... template with name "yes_4". WHY???

    – Akina
    9 mins ago














0












0








0








Structure



CREATE TABLE `template` (
`name` VARCHAR(16) NOT NULL COLLATE 'utf8_unicode_ci',
`valid` DATE NULL DEFAULT NULL,
UNIQUE INDEX `name` (`name`)
)
COLLATE='utf8_unicode_ci'
ENGINE=InnoDB;


Data



enter image description here



I am trying to select right template name based on date. "Valid" column represents date till template is valid. If Template have 0000-00-00 or NULL valid date, that means that this template is current (latest). Template names does not suggest order (they can be random string).



Scenario:



If I have user, that will be created let's say 2010-01-01, then select should pick template with name "yes_4".



Scenario:



User was created in 2018-01-01, then template selected should have name "agreement_x"



Scenario:



User created in 2019-01-15 will select row with name "template_2"



So far:



:date = - user created


query



SELECT * FROM `template` 
WHERE DATE(`valid`) < DATE(:date)
ORDER BY DATE(`valid`) DESC
LIMIT 1









share|improve this question







New contributor




Ing. Michal Hudak is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.












Structure



CREATE TABLE `template` (
`name` VARCHAR(16) NOT NULL COLLATE 'utf8_unicode_ci',
`valid` DATE NULL DEFAULT NULL,
UNIQUE INDEX `name` (`name`)
)
COLLATE='utf8_unicode_ci'
ENGINE=InnoDB;


Data



enter image description here



I am trying to select right template name based on date. "Valid" column represents date till template is valid. If Template have 0000-00-00 or NULL valid date, that means that this template is current (latest). Template names does not suggest order (they can be random string).



Scenario:



If I have user, that will be created let's say 2010-01-01, then select should pick template with name "yes_4".



Scenario:



User was created in 2018-01-01, then template selected should have name "agreement_x"



Scenario:



User created in 2019-01-15 will select row with name "template_2"



So far:



:date = - user created


query



SELECT * FROM `template` 
WHERE DATE(`valid`) < DATE(:date)
ORDER BY DATE(`valid`) DESC
LIMIT 1






mysql






share|improve this question







New contributor




Ing. Michal Hudak is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.











share|improve this question







New contributor




Ing. Michal Hudak is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









share|improve this question




share|improve this question






New contributor




Ing. Michal Hudak is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









asked 14 mins ago









Ing. Michal HudakIng. Michal Hudak

101




101




New contributor




Ing. Michal Hudak is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.





New contributor





Ing. Michal Hudak is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.






Ing. Michal Hudak is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.













  • 2010-01-01 ... template with name "yes_4". WHY???

    – Akina
    9 mins ago



















  • 2010-01-01 ... template with name "yes_4". WHY???

    – Akina
    9 mins ago

















2010-01-01 ... template with name "yes_4". WHY???

– Akina
9 mins ago





2010-01-01 ... template with name "yes_4". WHY???

– Akina
9 mins ago










1 Answer
1






active

oldest

votes


















0














Something like



(   SELECT * 
FROM `template`
WHERE DATE(`valid`) >= DATE(:date)
ORDER BY DATE(`valid`)
LIMIT 1
)
UNION ALL
( SELECT *
FROM `template`
WHERE DATE(`valid`) <= '1970-01-01' OR `valid` IS NULL
)
ORDER BY `valid` DESC
LIMIT 1


or



SELECT * 
FROM `template`
WHERE CASE WHEN DATE(`valid`) > '1970-01-01'
THEN `valid`
ELSE '2038-01-19'
END >= DATE(:date)
ORDER BY CASE WHEN DATE(`valid`) > '1970-01-01'
THEN `valid`
ELSE '2038-01-19'
END
LIMIT 1


and so on...





share























    Your Answer








    StackExchange.ready(function() {
    var channelOptions = {
    tags: "".split(" "),
    id: "182"
    };
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function() {
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled) {
    StackExchange.using("snippets", function() {
    createEditor();
    });
    }
    else {
    createEditor();
    }
    });

    function createEditor() {
    StackExchange.prepareEditor({
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: false,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: null,
    bindNavPrevention: true,
    postfix: "",
    imageUploader: {
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    },
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    });


    }
    });






    Ing. Michal Hudak is a new contributor. Be nice, and check out our Code of Conduct.










    draft saved

    draft discarded


















    StackExchange.ready(
    function () {
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fdba.stackexchange.com%2fquestions%2f230102%2fselect-document-based-on-date-range%23new-answer', 'question_page');
    }
    );

    Post as a guest















    Required, but never shown

























    1 Answer
    1






    active

    oldest

    votes








    1 Answer
    1






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    0














    Something like



    (   SELECT * 
    FROM `template`
    WHERE DATE(`valid`) >= DATE(:date)
    ORDER BY DATE(`valid`)
    LIMIT 1
    )
    UNION ALL
    ( SELECT *
    FROM `template`
    WHERE DATE(`valid`) <= '1970-01-01' OR `valid` IS NULL
    )
    ORDER BY `valid` DESC
    LIMIT 1


    or



    SELECT * 
    FROM `template`
    WHERE CASE WHEN DATE(`valid`) > '1970-01-01'
    THEN `valid`
    ELSE '2038-01-19'
    END >= DATE(:date)
    ORDER BY CASE WHEN DATE(`valid`) > '1970-01-01'
    THEN `valid`
    ELSE '2038-01-19'
    END
    LIMIT 1


    and so on...





    share




























      0














      Something like



      (   SELECT * 
      FROM `template`
      WHERE DATE(`valid`) >= DATE(:date)
      ORDER BY DATE(`valid`)
      LIMIT 1
      )
      UNION ALL
      ( SELECT *
      FROM `template`
      WHERE DATE(`valid`) <= '1970-01-01' OR `valid` IS NULL
      )
      ORDER BY `valid` DESC
      LIMIT 1


      or



      SELECT * 
      FROM `template`
      WHERE CASE WHEN DATE(`valid`) > '1970-01-01'
      THEN `valid`
      ELSE '2038-01-19'
      END >= DATE(:date)
      ORDER BY CASE WHEN DATE(`valid`) > '1970-01-01'
      THEN `valid`
      ELSE '2038-01-19'
      END
      LIMIT 1


      and so on...





      share


























        0












        0








        0







        Something like



        (   SELECT * 
        FROM `template`
        WHERE DATE(`valid`) >= DATE(:date)
        ORDER BY DATE(`valid`)
        LIMIT 1
        )
        UNION ALL
        ( SELECT *
        FROM `template`
        WHERE DATE(`valid`) <= '1970-01-01' OR `valid` IS NULL
        )
        ORDER BY `valid` DESC
        LIMIT 1


        or



        SELECT * 
        FROM `template`
        WHERE CASE WHEN DATE(`valid`) > '1970-01-01'
        THEN `valid`
        ELSE '2038-01-19'
        END >= DATE(:date)
        ORDER BY CASE WHEN DATE(`valid`) > '1970-01-01'
        THEN `valid`
        ELSE '2038-01-19'
        END
        LIMIT 1


        and so on...





        share













        Something like



        (   SELECT * 
        FROM `template`
        WHERE DATE(`valid`) >= DATE(:date)
        ORDER BY DATE(`valid`)
        LIMIT 1
        )
        UNION ALL
        ( SELECT *
        FROM `template`
        WHERE DATE(`valid`) <= '1970-01-01' OR `valid` IS NULL
        )
        ORDER BY `valid` DESC
        LIMIT 1


        or



        SELECT * 
        FROM `template`
        WHERE CASE WHEN DATE(`valid`) > '1970-01-01'
        THEN `valid`
        ELSE '2038-01-19'
        END >= DATE(:date)
        ORDER BY CASE WHEN DATE(`valid`) > '1970-01-01'
        THEN `valid`
        ELSE '2038-01-19'
        END
        LIMIT 1


        and so on...






        share











        share


        share










        answered 29 secs ago









        AkinaAkina

        4,0361311




        4,0361311






















            Ing. Michal Hudak is a new contributor. Be nice, and check out our Code of Conduct.










            draft saved

            draft discarded


















            Ing. Michal Hudak is a new contributor. Be nice, and check out our Code of Conduct.













            Ing. Michal Hudak is a new contributor. Be nice, and check out our Code of Conduct.












            Ing. Michal Hudak is a new contributor. Be nice, and check out our Code of Conduct.
















            Thanks for contributing an answer to Database Administrators Stack Exchange!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid



            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.


            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fdba.stackexchange.com%2fquestions%2f230102%2fselect-document-based-on-date-range%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            Liste der Baudenkmale in Friedland (Mecklenburg)

            Single-Malt-Whisky

            Czorneboh