MySQL понимание группы с объединенной таблицей

myList = [[1]*4] * 3 создает один объект списка [1,1,1,1] в памяти и копирует его ссылку 3 раза. Это эквивалентно obj = [1,1,1,1]; myList = [obj]*3. Любая модификация obj будет отражена в трех местах, где obj упоминается в списке. Правильным утверждением будет:

myList = [[1]*4 for _ in range(3)]

или

myList = [[1 for __ in range(4)] for _ in range(3)]

. Важно отметить, что * оператор в основном используется для создания список литералов. Поскольку 1 является литералом, значит, obj =[1]*4 создаст [1,1,1,1], где каждый 1 будет атомарным, а не ссылкой 1, повторяемым 4 раза. Это означает, что если мы obj[2]=42, то obj станет [1,1,42,1] не [42,42,42,42], как могут предположить некоторые.

0
задан dataviews 24 March 2019 в 15:16
поделиться

1 ответ

Группировка байтов для функции агрегирования: MIN (), MAX (), COUNT (). .. и предназначен для определения того, в каком столбце должна выполняться функция агрегации.

Если вы ищете конкретный упорядоченный результат, вы должны использовать ORDER BY, который работает для значения столбцов, как есть

select tablea.order_number, tablea.order_name, tableb.tracking_number
from tablea
join table b on tablea.order_number = tableb.order_number
order  by tablea.order_number
0
ответ дан scaisEdge 24 March 2019 в 15:16
поделиться
Другие вопросы по тегам:

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