Можно ли извлечь целое число из названий дней, то есть «Mon», Втр»,„ср“с помощью оператора SQLExtract номер дня от дня строки
Например:
Mon = 1
Tue = 2
Wed = 3
Можно ли извлечь целое число из названий дней, то есть «Mon», Втр»,„ср“с помощью оператора SQLExtract номер дня от дня строки
Например:
Mon = 1
Tue = 2
Wed = 3
Если вы просто иметь не DATETIME поле с только пн, вт, ср, и т.д., вы можете использовать STR_TO_DATE()
и WEEKDAY()
функции, чтобы придумать что-то вроде этого:
SELECT WEEKDAY(STR_TO_DATE(CONCAT('201011 ', yourField), '%X%V %W')) + 1 AS WeekIndex;
Test Корпус:
SELECT WEEKDAY(STR_TO_DATE(CONCAT('201011 ', 'Mon'), '%X%V %W')) + 1 AS WeekIndex;
+-----------+
| WeekIndex |
+-----------+
| 1 |
+-----------+
SELECT WEEKDAY(STR_TO_DATE(CONCAT('201011 ', 'Tue'), '%X%V %W')) + 1 AS WeekIndex;
+-----------+
| WeekIndex |
+-----------+
| 2 |
+-----------+
SELECT WEEKDAY(STR_TO_DATE(CONCAT('201011 ', 'Wed'), '%X%V %W')) + 1 AS WeekIndex;
+-----------+
| WeekIndex |
+-----------+
| 3 |
+-----------+
SELECT WEEKDAY(STR_TO_DATE(CONCAT('201011 ', 'Thu'), '%X%V %W')) + 1 AS WeekIndex;
+-----------+
| WeekIndex |
+-----------+
| 4 |
+-----------+
Try Область:
SELECT FIELD('Mon', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun');
-> 1
SELECT FIELD('Thu', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun');
-> 4
http://dev.mysql.com/doc/refman/5.4/en/string-functions.html#function_field
Если поле является дата, просто используйте
SELECT DATE_FORMAT(my.field, "%w");
Дополнительная информация о MySQLs DATE_FORMAT можно optained here ,
ли вам нужно только, чтобы работать на английском языке? –