użycie Group concat w PHPMYADMIN pokaże wynik jako [BLOB - 3B]
Mam zapytanie, które używa GROUP_CONCAT mysql na polu integer.
Używam PHPMYADMIN do opracowania tego zapytania. Mój problem, że zamiast pokazywać 1,2, który jest wynikiem połączonego pola, dostaję [BLOB - 3B].
Zapytanie to
SELECT rec_id,GROUP_CONCAT(user_id)
FROM t1
GROUP BY rec_id
(oba pola są niepodpisaną liczbą całkowitą, oba nie są unikalne)
Co dodać, aby zobaczyć rzeczywiste wyniki?
6 answers
Wygląda na to, że GROUP_CONCAT oczekuje, że wartość będzie ciągiem znaków. Właśnie wpadłem na ten sam problem. Rozwiązałem to konwertując kolumnę int na ciąg znaków w ten sposób:
SELECT rec_id,GROUP_CONCAT(CONVERT(user_id, CHAR(8)))
FROM t1
GROUP BY rec_id
Pomyślałem, że się podzielę, gdybyś nadal miał z tym problem.Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2010-04-26 19:40:29
Zgodnie z dokumentacją MySQL, CAST(expr AS type)
jest standardowym SQL i dlatego powinien być udoskonalony. Można również pominąć Długość łańcucha. Dlatego proponuję:
SELECT rec_id, GROUP_CONCAT(CAST(user_id AS CHAR))
FROM t1
GROUP BY rec_id
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2010-11-05 11:23:40
Dla mnie to pomogło (znalazłem to w tym blogu):
W moim przypadku parametr na GROUP_CONCAT
był string, ale funkcja nadal powodowała BLOB, ale konwersja wyniku GROUP_CONCAT
zadziałała.
CONVERT(GROUP_CONCAT(user_id) USING 'utf8')
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2013-01-11 09:03:13
Tuż nad wynikiem zapytania (po lewej stronie) zobaczysz +options
. Naciśnij i zaznacz
Pokaż zawartość Bloba
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2011-06-16 15:46:41
Możesz to zrobić:
set session group_concat_max_len = 512;
Jeśli group_concat_max_len jest większy niż 512, zapytanie zwróci bajt []. Ale można przejść do sznurka.
System.Text.Encoding.Default.GetString((byte[])DataTable.Rows[0][0]);
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2016-02-11 11:01:09
Jeśli masz dostęp do pliku config.inc.php
w katalogu phpMyAdmin, to
Myślę, że najlepszym rozwiązaniem jest zmiana tej linii:
$cfg['Servers'][$i]['extension'] = 'mysql';
Do tego:
$cfg['Servers'][$i]['extension'] = 'mysqli';
Jeśli masz dostępne rozszerzenie mysqli, użyj go. Jest bezpieczniejszy, nieco bardziej zoptymalizowany i domyślnie lepiej radzi sobie z utf-8 typu BLOB. Wpisy [BLOB] powinny być wyświetlane jako ich wartości bez konieczności dodawania innych specjalnych opcji konfiguracyjnych.
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2011-06-23 23:28:57