Я думаю, что ссылка у micahwittman's имеет лучшее практическое решение для этих ограничений MySQL: установите часовой пояс сеанса в UTC, когда вы подключаетесь:
SET SESSION time_zone = '+0:00'
Затем вы просто отправляете его в Unix временные метки и все должно быть хорошо.
Да, вы можете использовать метод GetValues
:
var values = Enum.GetValues(typeof(Foos));
Или типизированную версию:
var values = Enum.GetValues(typeof(Foos)).Cast<Foos>();
Я давно добавил вспомогательную функцию в свою частную библиотеку именно для этого повод:
public static class EnumUtil {
public static IEnumerable<T> GetValues<T>() {
return Enum.GetValues(typeof(T)).Cast<T>();
}
}
Использование:
var values = EnumUtil.GetValues<Foos>();
foreach (EMyEnum val in Enum.GetValues(typeof(EMyEnum)))
{
Console.WriteLine(val);
}
Благодарим Джона Скита здесь: http://bytes.com/groups/net-c/266447-how-loop-each-items-enum
foreach (Foos foo in Enum.GetValues(typeof(Foos)))
{
...
}
ОБНОВЛЕНО
Некоторое время спустя я вижу комментарий, который возвращает меня к моему старому ответу, и я думаю, что сейчас я бы сделал это по-другому. Сейчас я бы написал:
private static IEnumerable<T> GetEnumValues<T>()
{
// Can't use type constraints on value types, so have to do check like this
if (typeof(T).BaseType != typeof(Enum))
{
throw new ArgumentException("T must be of type System.Enum");
}
return Enum.GetValues(typeof(T)).Cast<T>();
}
static void Main(string[] args)
{
foreach (int value in Enum.GetValues(typeof(DaysOfWeek)))
{
Console.WriteLine(((DaysOfWeek)value).ToString());
}
foreach (string value in Enum.GetNames(typeof(DaysOfWeek)))
{
Console.WriteLine(value);
}
Console.ReadLine();
}
public enum DaysOfWeek
{
monday,
tuesday,
wednesday
}
Да. Используйте метод GetValues ()
в классе System.Enum
.