1. SQL / Говнокод #9202

    −113

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    with mycte as
    (
    
    select dateadd(dd, 1,@dato1)as  Dato
    
    union all
    select Dato + 1
    from    mycte    
    where   Dato + 1 <= @dato2
    )
    select count(Dato) as antall
    from    mycte
    where Dato <=@dato2
    OPTION (MAXRECURSION 0)

    Суровые нордические ребята пытаются найти разницу в днях между двумя датами с помощью рекурсии.
    И ведь dateadd они знают, а про datediff нет.
    Так же веселит OPTION (MAXRECURSION 0), который обычно устанавливают с параметром отличным от 0 в тех случаях, когда рекурсия убегает в бесконечность, чтобы хоть как-то ограничить ее. Видимо, эхо дебаггинга сего замечательного кода.

    Запостил: DBdev, 23 Января 2012

    Комментарии (0) RSS

    Добавить комментарий

    Ошибка компиляции комментария:
    1. Гости могут высказаться только в понедельник, среду, четверг или воскресение
    ava Семь раз отмерь — один отрежь, guest!
    А не использовать ли нам bbcode?
    • [b]жирный[/b] — жирный
    • [i]курсив[/i] — курсив
    • [u]подчеркнутый[/u] — подчеркнутый
    • [s]перечеркнутый[/s] — перечеркнутый
    • [blink]мигающий[/blink] — мигающий
    • [color=red]цвет[/color] — цвет (подробнее)
    • [size=20]размер[/size] — размер (подробнее)
    • [code=<language>]some code[/code] (подробнее)
    Проверочный код