Преобразуйте число месяца в функцию имени месяца в SQL

В Java все переменные, которые вы объявляете, на самом деле являются «ссылками» на объекты (или примитивы), а не самими объектами.

При попытке выполнить один метод объекта , ссылка просит живой объект выполнить этот метод. Но если ссылка ссылается на NULL (ничего, нуль, void, nada), то нет способа, которым метод будет выполнен. Тогда runtime сообщит вам об этом, выбросив исключение NullPointerException.

Ваша ссылка «указывает» на нуль, таким образом, «Null -> Pointer».

Объект живет в памяти виртуальной машины пространство и единственный способ доступа к нему - использовать ссылки this. Возьмем этот пример:

public class Some {
    private int id;
    public int getId(){
        return this.id;
    }
    public setId( int newId ) {
        this.id = newId;
    }
}

И в другом месте вашего кода:

Some reference = new Some();    // Point to a new object of type Some()
Some otherReference = null;     // Initiallly this points to NULL

reference.setId( 1 );           // Execute setId method, now private var id is 1

System.out.println( reference.getId() ); // Prints 1 to the console

otherReference = reference      // Now they both point to the only object.

reference = null;               // "reference" now point to null.

// But "otherReference" still point to the "real" object so this print 1 too...
System.out.println( otherReference.getId() );

// Guess what will happen
System.out.println( reference.getId() ); // :S Throws NullPointerException because "reference" is pointing to NULL remember...

Это важно знать - когда больше нет ссылок на объект (в пример выше, когда reference и otherReference оба указывают на null), тогда объект «недоступен». Мы не можем работать с ним, поэтому этот объект готов к сбору мусора, и в какой-то момент VM освободит память, используемую этим объектом, и выделит другую.

201
задан abatishchev 23 May 2012 в 03:09
поделиться

5 ответов

Немного hacky, но должно работать:

SELECT DATENAME(month, DATEADD(month, @mydate-1, CAST('2008-01-01' AS datetime)))
152
ответ дан Alexander Kojevnikov 23 November 2019 в 05:02
поделиться

Я думаю, что это - лучший способ получить 114-месячное имя , когда у Вас есть 115-месячный номер

Select DateName( month , DateAdd( month , @MonthNumber , 0 ) - 1 )

Или

Select DateName( month , DateAdd( month , @MonthNumber , -1 ) )
258
ответ дан Robert Harvey 23 November 2019 в 05:02
поделиться

Можно использовать встроенное CONVERT функция

select CONVERT(varchar(3), Date, 100)  as Month from MyTable.

, Это отобразит сначала 3 символа месяца (ЯНВАРЬ, ФЕВРАЛЬ и т.д.)

6
ответ дан Marcus 23 November 2019 в 05:02
поделиться

В некоторых локалях как иврит, существуют месяцы прыжка иждивенец в год так для предотвращения ошибок в таких локалях, Вы могли бы рассмотреть следующее решение:

SELECT DATENAME(month, STR(YEAR(GETDATE()), 4) + REPLACE(STR(@month, 2), ' ', '0') + '01')     
4
ответ дан Jim Burger 23 November 2019 в 05:02
поделиться
SELECT DATENAME(month, GETDATE()) AS 'Month Name'
90
ответ дан 23 November 2019 в 05:02
поделиться
Другие вопросы по тегам:

Похожие вопросы: