Что-то вроде этого должно работать: Из Блога
SELECT * FROM
(
SELECT a.*, rownum r__
FROM
(
SELECT * FROM ORDERS WHERE CustomerID LIKE 'A%'
ORDER BY OrderDate DESC, ShippingDate DESC
) a
WHERE rownum < ((pageNumber * pageSize) + 1 )
)
WHERE r__ >= (((pageNumber-1) * pageSize) + 1)
Frans Bouma
Вы можете получить доступ к данным маршрута из класса контроллера следующим образом:
var actionName = ControllerContext.RouteData.GetRequiredString ("action");
Или, если "action" не является обязательной частью вашего маршрута, вы можете просто индексировать данные маршрута как обычно.
Единственный способ, который я могу придумать, - это использовать класс StackFrame . Я бы не рекомендовал его, если вы имеете дело с кодом, критичным к производительности, но вы можете его использовать. Единственная проблема в том, что StackFrame предоставляет вам все методы, которые были вызваны до этого момента, но нет простого способа определить, какой из них является методом Action, но, возможно, в вашей ситуации вы знаете, на сколько слоев Action будет быть. Вот пример кода:
[HandleError]
public class HomeController : Controller
{
public void Index()
{
var x = ShowStackFrame();
Response.Write(x);
}
private string ShowStackFrame()
{
StringBuilder b = new StringBuilder();
StackTrace trace = new StackTrace(0);
foreach (var frame in trace.GetFrames())
{
var method = frame.GetMethod();
b.AppendLine(method.Name + "<br>");
foreach (var param in method.GetParameters())
{
b.AppendLine(param.Name + "<br>");
}
b.AppendLine("<hr>");
}
return b.ToString() ;
}
}
Что ж, если вы находитесь в контроллере, вы знаете, какое действие вызывается. Я предполагаю, что у вас есть класс, который используется в контроллере, который должен вести себя по-разному в зависимости от вызываемого действия. Если это так, я бы передал строковое представление действия объекту, которому нужна эта информация, из метода действия. Некоторые примеры кода от вас действительно прояснят, что вам нужно делать. Вот пример кода, о котором я думаю:
public ActionResult TestControllerAction()
{
var action = new TestControllerAction();
var objectWithBehaviorBasedOnAction = new MyObjectWithBehaviorBasedOnAction();
objectWithBehaviorBasedOnAction.DoSomething(action);
}
public class MyObjectWithBehaviorBasedOnAction: IMyBehaviorBasedOnAction
{
public void DoSomething(IControllerAction action)
{
// generic stuff
}
public void DoSomething(TestControllerAction action)
{
// do behavior A
}
public void DoSomething(OtherControllerAction action)
{
// do behavior b
}
}
public interface IMyBehaviorBasedOnAction
{
void DoSomething(IControllerAction action);
}