Замена для для …, если повторение массива

Мне кажется, вам нужен такой запрос:

SELECT *
FROM (SELECT *,
        ROW_NUMBER() OVER (PARTITION BY oName ORDER BY oDate DESC) seq
    FROM yourTable) t
WHERE (seq <= 2)
ORDER BY oDate; 
8
задан Community 12 September 2008 в 05:14
поделиться

5 ответов

Инкремент в оригинале foreach цикл не будет влиять на содержание массива, единственный способ сделать, это остается a for цикл:

for(int i = 0; i < intArray.Length; ++i)
{
    if(intArray[i] > 3) ++intArray[i];
}

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

var newArray1 = from i in intArray select ((i > 3) ? (i + 1) : (i));
var newArray2 = intArray.Select(i => (i > 3) ? (i + 1) : (i));

Используя where (или эквивалентный), как показано в некоторых из других ответов, исключит любые значения, меньше чем или равные 3 от получающейся последовательности.

var intArray = new int[] { 10, 1, 20, 2 };
var newArray = from i in intArray where i > 3 select i + 1;
// newArray == { 11, 21 }

Существует a ForEach метод на массивах, которые позволят Вам использовать лямбду, функционирует вместо a foreach блок, хотя для чего-то большего чем вызова метода я придерживался бы с foreach.

intArray.ForEach(i => DoSomething(i));
5
ответ дан 5 December 2019 в 21:24
поделиться

В C# можно применить выборочную обработку на что-либо, что живет в IEnumerable как это:

intArray.Where(i => i > 3).ConvertAll();
DoStuff(intArray.Where(i => i 3));

И т.д.

2
ответ дан 5 December 2019 в 21:24
поделиться

В Python у Вас есть фильтр и карта, которая может поэтому, что Вы хотите:

map(lambda x: foo(x + 1) filter(lambda x: x > 3, intArray))

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

[f(x + 1) for x in intArray if x > 3]
1
ответ дан 5 December 2019 в 21:24
поделиться

Зависит от языка и что необходимо сделать, "карта", как это называют на многих языках, могла быть тем, что Вы ищете. Я не знаю C#, но согласно этой странице.NET, 2,0 вызова отображают "ConvertAll".

Значение "карты" довольно просто - берут список и применяют функцию к каждому элементу его, возвращая новый список. Можно также искать "фильтр", который дал бы Вам список объектов, которые удовлетворяют предикат в другом списке.

-1
ответ дан 5 December 2019 в 21:24
поделиться

в Ruby:

intArray.select { |x| x > 3 }.each do |x|
  # do other processing
end

или если "другая обработка" является короткой остротой:

intArray.select { |x| x > 3 }.each { |x| something_that_uses x }

наконец, если Вы хотите возвратить новый массив, содержащий результаты обработки тех элементов, больше, чем 3:

intArray.select { |x| x > 3 }.map { |x| do_something_to x }
0
ответ дан 5 December 2019 в 21:24
поделиться
Другие вопросы по тегам:

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