Мне кажется, вам нужен такой запрос:
SELECT *
FROM (SELECT *,
ROW_NUMBER() OVER (PARTITION BY oName ORDER BY oDate DESC) seq
FROM yourTable) t
WHERE (seq <= 2)
ORDER BY oDate;
Инкремент в оригинале 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));
В C# можно применить выборочную обработку на что-либо, что живет в IEnumerable как это:
intArray.Where(i => i > 3).ConvertAll();
DoStuff(intArray.Where(i => i 3));
И т.д.
В Python у Вас есть фильтр и карта, которая может поэтому, что Вы хотите:
map(lambda x: foo(x + 1) filter(lambda x: x > 3, intArray))
Существуют также понимания списка, которые могут сделать обоих в одном легком операторе:
[f(x + 1) for x in intArray if x > 3]
Зависит от языка и что необходимо сделать, "карта", как это называют на многих языках, могла быть тем, что Вы ищете. Я не знаю C#, но согласно этой странице.NET, 2,0 вызова отображают "ConvertAll".
Значение "карты" довольно просто - берут список и применяют функцию к каждому элементу его, возвращая новый список. Можно также искать "фильтр", который дал бы Вам список объектов, которые удовлетворяют предикат в другом списке.
в 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 }