Jump to content
Fórum Script Brasil
  • 0
Sign in to follow this  
jothaz

Usando WHILE para gerar intervalo de datas - massa de testes

Question

DECLARE  @TMP TABLE (
    DATA DATETIME NULL
)

DECLARE @DIA INT,
        @QTDE_MES INT,
        @MES_INI INT,
        @ANO_INI INT,
        
        @DT_AUX VARCHAR(10),
        @AUX INT


SELECT  @DIA         = 10,     --Define o Dia inicial
        @QTDE_MES     = 12,     --Define a quantidade de meses à ser gerado
        @MES_INI     = 6,      --Define o Mês inicial
        @ANO_INI     = 2008    --Define Ano inicial

SELECT @AUX = 1

WHILE    @AUX <= @QTDE_MES 
BEGIN
    --
    --Monta data
    SELECT @DT_AUX = CONVERT(CHAR(4),@ANO_INI) + '/' + CONVERT(CHAR(2),@MES_INI) + '/' + CONVERT(CHAR(2),@DIA)
    --
    --Inserre na tabela temporária
    INSERT @TMP (DATA) VALUES (@DT_AUX)
    --
    --Incremeta variável do LOOP
    SELECT @AUX = @AUX + 1
    --
    --Se Mês igual a 12 re-inicia Mês e soma 1 no Ano
    IF @MES_INI = 12
    BEGIN
        SELECT @MES_INI = 0
         SELECT @ANO_INI = @ANO_INI + 1
    END 
    --
    --Incrementa no Mês
     SELECT @MES_INI = @MES_INI + 1

END

SELECT * FROM @TMP

Considerações finais:

Este loop pode ser adaptado para gerar intervalo entre números.

Fonte/Autor/link

AUTOR: "Jothaz"

Dúvidas, criticas, contribuições, correções e adições serão bem vindas.

Share this post


Link to post
Share on other sites

0 answers to this question

Recommended Posts

There have been no answers to this question yet

Join the conversation

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

Guest
Answer this question...

×   Pasted as rich text.   Paste as plain text instead

  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.

Sign in to follow this  



  • Forum Statistics

    • Total Topics
      148409
    • Total Posts
      643823
×
×
  • Create New...